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 Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...