SQL插入数据的详细总结

393 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第5天,点击查看活动详情

插入数据

数据插入

INSERT是用来插入行到数据库表的。插入可以用几种方式使用:

  • 插入完整的行
  • 插入行的一部分
  • 插入多行
  • 插入某些查询的结果

插入完整的行

INSERT INTO customers
VALUES (NULL,'PeP E.LaPew','100 Main Street','Los Angeles','CA','90046','USA',NULL,NULL);

🚛INSERT语句一般是不会产生输出的。

虽然上面的语法很简单但是不安全。他是很依赖表中列的定义次序,并且还依赖于其次序容易获得的信息。即使你能得到这种信息,你也不能保证下一次表结构变动后各个项保持完全相同的次序。

所以我们这样写:

INSERT INTO customers(cust_name,cust_address,cust_city,cust_state,cust_zip,cust_country,cust_contact,cust_email)
VALUES ('PeP E.LaPew','100 Main Street','Los Angeles','CA','90046','USA',NULL,NULL);

所以你最好就写上面这种。

⏰但是不管那种INSERT语句都必须给出values的正确数目。如果不提供列名,则必须给每个表列提供提供一个值。如果提供列名,则必须对每个列出的列一个值。如果不这样,你是插入不成功。

⏰使用上面这种语法,你是可以省略一些列的,省略的列需要满足这些特点:

  1. 该列定义为允许null的值
  2. 在表的定义中给出默认值。

插入多个行

INSERT可以插入一行到一个表中。但是你如果想插入多个行怎么办呢?其实就是使用多条INSERT语句,但是你可以一次性提交,用;分好隔开就好了。

INSERT INTO 表名(列名1,列名1) 
VALUES (信息1,信息1);
INSERT INTO 表名(列名2,列名2) 
VALUES (信息2,信息2);

或者如果列名相同,你还可以这样:

INSERT INTO 表名(列名1,列名1) 
VALUES (信息1,信息1),
VALUES (信息2,信息2);

插入检索出的数据

INSERT还有一个很厉害的功能,他可以将一条SELECT语句的结果插入表中。这就是所谓的INSERT SELECT 。

例:我们从表2 的内容要复制到表1.

INSERT INTO1(列名1,列名2,列名3SELECT 列名1,列名2,列名3 FROM2;

有一个你需要注意的问题,就是虽然你看我写的列名是对应相等的,但是,是没这个必要相等的,mysql只管把对应位置的给你插入进去就好,它不管上下列名相同与否。

还有就是,对于像cust_id 这种你没办法保证表1表2不重复的列,你就可以省略这一列,让系统去生成id就好。