MySQL快速回顧:插入操做

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

《MySQL必知必會》是先講了查詢,可是沒有記錄就沒法查詢,因此先將如何添加數據。sql

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

5.1 插入數據

MySQL使用 INSERT來插入(或添加)行(記錄)到數據庫表中。插入可用如下幾種方式使用:安全

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

5.2 插入完整的行(記錄)

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

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

# 寫法:
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, '張三', '男');

注意:字符串或字符須要使用''(單引號)圈起來。字符串

輸出:若是成功的話table

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子句以過濾插入的數據。
相關文章
相關標籤/搜索