MySQL快速回顧:插入操作

来源:https://www.cnblogs.com/flunggg/archive/2020/01/13/12186390.html
-Advertisement-
Play Games

前提要述:參考書籍《MySQL必知必會》 《MySQL必知必會》是先講了查詢,但是沒有記錄就無法查詢,所以先將如何添加數據。 表已經知道怎麼創建了,隨便創兩張。 5.1 插入數據 MySQL使用 INSERT來插入(或添加)行(記錄)到資料庫表中。插入可用以下幾種方式使用: 插入完整的行(記錄); ...


前提要述:參考書籍《MySQL必知必會》

《MySQL必知必會》是先講了查詢,但是沒有記錄就無法查詢,所以先將如何添加數據。

表已經知道怎麼創建了,隨便創兩張。

5.1 插入數據

MySQL使用 INSERT來插入(或添加)行(記錄)到資料庫表中。插入可用以下幾種方式使用:

  • 插入完整的行(記錄);
  • 插入行的一部分;
  • 插入多行;
  • 插入某些查詢結果。

5.2 插入完整的行(記錄)

什麼叫完整的行,即插入的有效數據都可以對應表中的每一列。

把數據插入表中,最簡單的方法是使用基本的INSERT語法,需要指定表名和被插入到新行中的值,格式:

# 寫法:
INSERT INTO <table_name> VALUES(value1,value2,...);
# 規範寫法:
INSERT INTO <table_name>(field1, field2, ...) VALUES(value1,value2,...);

解釋:

  • 如果使用第一種寫法,雖然很簡單,但是並不安全,應該儘量避免使用。因為該語句高度依賴於表中列的次序,並且還依賴其次序容易獲得的信息。即使可得到這種次序信息,也不能保證下次表結構變動後各個列保持完全相同的次序。所以在開發中如果這樣寫,那麼就是把插入語句寫死了。因為資料庫表中的列的順序有可能可能會改變,一旦改變,就會出現致命錯誤,比如:一個varchar類型的可能會被插入到char中,如果超長度可能會報錯,而且varchar是大範圍而char是小範圍,可能會導致數據丟失;而如果一個浮點型的數據因為列順序的改變插入到了一個整型的列中,這又不會報錯,所以也很難找錯。
  • 推薦使用規範寫法,特別是在開發時編寫sql語句。因為一旦指定列名,那麼VALUES必須以其指定的次序匹配指定的列名,不一定按各個列出現在實際表中的次序。 所以即使表的結構改變,此INSERT語句仍然可以正確工作。
  • 第一種寫法必須完整的給出表中的全部列的值,並且還得按照表中列的次序;而規範寫法不用,因為會根據(field1, field2, ...)來進行賦值,即使跟表中的列的次序不一樣,或者一些列不想賦值。

例子:在學生表中插入數據

INSERT INTO student(stu_id, stu_name, stu_sex)  VALUES(1, '張三', '男');

註意:字元串或字元需要使用''(單引號)圈起來。

輸出:如果成功的話

Query OK, 1 row affected (0.01 sec)

而如果在主鍵使用了自增長(AUTO_INCREMENT),那麼則可以這樣寫

INSERT INTO student(stu_id, stu_name, stu_sex)  VALUES(null, '張三', '男');

或者,不寫主鍵:

INSERT INTO student(stu_name, stu_sex)  VALUES('張三', '男');

也就是插入時,在主鍵的位置直接插入null或者不寫預設就是賦給null,MySQL會因為AUTO_INCREMENT自己給它賦值。


  • 如果對錶中不允許NULL值且沒有預設值的列不給出值(插入時省略了),則MySQL將產生一條錯誤信息,並且相應的行插入不成功。
  • 規範寫法哪些列可以省略不寫:
    • 該列定義為允許NULL值(無值或空值);
    • 在表定義中給出預設值。也就表示如果在插入時不給出值,就會使用預設值;
    • 使用AUTO_INCREMENT的列。
  • INSERT操作可能很耗時(特別是有很多索引需要更新時),而且它可能降低等待處理的SELECT語句的性能。如果數據檢索是最重要的,則可以通過在INSERT和INTO之間添加關鍵字LOW_PRIORITY,指示MySQL降低INSERT語句的優先順序。
INSERT LOW_PRIORITY INTO
  • UPDATE操作和DELETE操作也適用。

5.3 插入多個行

INSERT可以插入一行到一個表中,也可以插入多行到一個表中,第一種方式就是寫多條INSERT語句,還有一種方式就是在一條INSERT語句中插入多行。

語法:

INSERT INTO <table_name>(
    field1,
    field2,
    ...
    )
    VALUES(
        valueA1,
        valueA2,
        ...
        ),
        (
        valueB1,
        valueB2,
        ...
    );

此寫法可以提供INSERT的性能,因為MySQL用單條INSERT語句處理多個插入比使用多條INSERT快。

5.4 插入檢索出的數據

INSERT語句可以利用一條SELECT語句查詢的結果插入到表中。也就是所謂的INSERT SELECT,它是由一條INSERT語句和一條SELECT語句構成。

比如我需要把一張表的數據複製到另一張表,語法:

INSERT INTO <new_table_name>(field1, field2, ...) 
    SELECT field1, field2 FROM <old_table_name>;
# 或 也就是列名可以不同
INSERT INTO <new_table_name>(field1, field2, ...) 
    SELECT f1, f2 FROM <old_table_name>;

註意:如果新表不存在則報錯。
解釋:

  • 先使用SELECT語句從舊表中查詢出數據,然後再使用INSERT語句把查詢的結果插入到新表中。
  • SELECT列出的每一個列對應於後所跟的列表中的每一個列。
  • 如果為空,即沒有行可以插入也不會報錯。
  • 如果能保證從舊表導入到新表(假設新表有數據)的主鍵值不會重覆,那麼插入時可以省略這主鍵,比如有AUTO_INCREMENT的主鍵就可以省略。
  • 在INSERT和SELECT語句中使用相同的列名,但是不一定要求列名匹配。實際上,MySQL甚至不關心SELECT返回的列名。它使用的是列的位置,因此SELECT中的第一列(不管列名)將用來填充表列中指定的第一個列,第二列將用來填充表列中指定的第二列等。
  • INSERT SELECT中SELECT語句可包含WHERE子句以過濾插入的數據。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JVM性能優化原則: 代碼運算性能、記憶體回收、應用配置(影響Java程式主要原因是垃圾回收機制) 代碼層優化: 避免過多迴圈嵌套、調用和複雜邏輯。 Tomcat調優主要內容 1、增加最大連接數 2、調整工作模式 3、啟用gzip壓縮 4、調整JVM記憶體大小 5、作為web伺服器時、無Apache整合 ...
  • 選擇在Linux下安裝redis,現在採用虛擬機安裝的centos7 進行安裝的 1.安裝gcc redis是c語言編寫的 yum -y install gcc 2.下載redis安裝包,在root目錄下執行 wget http://download.redis.io/releases/redis- ...
  • 在Oracle資料庫中,我們使用session相關視圖(v$session、v$active_session_history,dba_hist_active_session_history等)查找問題時,往往可以定位到相應的主機名,但是,想要更進一步查找IP地址時,卻發現各個數據字典表裡面都沒有記錄... ...
  • 記錄一次 mysql 5.7 下,出現重啟資料庫後不能載入特定表的問題處理。 搜索了很多的類似的錯誤,大多都是說因為外鍵同名的索引丟失的情況。但在5.7這個版本下,會禁止更新外鍵關聯的索引。 最後經過分析,發現是之前更新了主外鍵的字元集導致的。資料庫的預設字元集是utf8mb4(預期是uft8),如 ...
  • mac 安裝 navicat for mysql 直接安裝 首先打開mac控制台輸入命令行:sudo spctl --master-disable 百度盤,提取碼: vrtr 失效請留言,會及時更新,謝謝 ...
  • MySQL 創建資料庫: CREATE DATABASE [IF NOT EXISTS] <資料庫名> [[DEFAULT] CHARACTER SET <字元集名>] [[DEFAULT] COLLATE <校對規則名>]; 註: [IF NOT EXISTS] 方法判斷資料庫是否存在,不存在才創 ...
  • php操作資料庫八步走 <?php // 1、建立連接 $connection = mysqli_connect('127.0.0.1', 'root', '123456'); // 2、判斷連接是否成功 if (mysqli_connect_error() != null) { die(mysql ...
  • 前提要述:參考書籍《MySQL必知必會》 利用空閑時間快速回顧一些資料庫基礎。 4.1 連接 在最初安裝MySQL,可能會要求你輸入一個管理登錄(通常為root)和一個口令(密碼)。 連接MySQL需要以下信息: 主機名(電腦名)——如果連接到本地MySQL伺服器,為localhost; 埠(如 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...