insert into 语句的四种写法

方式1、 INSERT INTO t1(field1,field2) VALUE(v001,v002);           

 明确只插入一条Value

方式2、 INSERT INTO t1(field1,field2) VALUES(v101,v102),(v201,v202),(v301,v302),(v401,v402);

在插入批量数据时 方式2 优于 方式1.

【特注】当 id 为自增,即  id INT PRIMARY KEY AUTO_INCREMENT 时,执行 insert into 语句,需要将除 id 外的所有 field 列举出来(有没有感觉,好不方便,期待 mysql 提供一个简便方法来标记这种情况,因为在早测试数据的时候,普遍会使用,而列举出除 id 外所有字段,真有麻烦感)。

方式3.1、  INSERT INTO t2(field1,field2) SELECT colm1,colm2 FROM t1 WHERE ……

这里简单说一下,由于可以指定插入到 talbe2 中的列,以及可以通过相对较复杂的查询语句进行数据源获取,可能使用起来会更加的灵活一些,但我们也必须注意,我们在指定目标表的列时,一定要将所有非空列都填上,否则将无法进行数据插入,还有一点比较容易出错的地方就是,当我们写成如下简写格式:

方式3.2、  INSERT INTO t2 SELECT colm1,colm2,…… FROM t1

此时,我们如果略掉了目标表的列的话,则默认会对目标表的全部列进行数据插入,且 SELECT 后面的列的顺序 必须和目标表中的列的定义顺序完全一致 才能完成正确的数据插入,这是一个很容易被忽略的地方,值得注意。

【特注】由于插入操作只粗略地对表 t1、t2 按顺序对所有字段进行 [数据类型] 检查,不对 [字段名] 核对。这是把双刃剑,既提供便利,又存在可能因粗心造成风险。在使用中,需确认顺序,使用中建议使用 [方式3.1] 或 [方式4].

方式4、INSERT INTO 表名 SET 列名1 = 列值1,列名2=列值2,...;(博友提供,感谢)

不过用INSERT INTO SET这种方式,不能批量增加数据。(参考:mysql数据库中插入数据INSERT INTO SET的优势

  • 43
    点赞
  • 188
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
根据表格数据批量生成Insert Into语句 本人在登陆CSDN论坛的数据库板块时,常看到很多网友提关于数据库的各种问题。而这些问题中有很多是要使用范例数据的。但是很多提问的朋友却没有把这些范例数据库的INSERT INTO语句写出来,只是以这种方式提供:id dates num1 num2---------------------------------------------------------0001 2004-4-5 2000 3000 0002 2004-4-5 1000 5000 0003 2005-6-7 1500 3000 0004 2006-5-6 1200 3000 0005 2005-6-7 1300 3400 对于回答问题网友来说,见表和构建INSERT INTO语句是很费时间的,很多时候用于这里的时间比写出要求的SQL语句用的时间还多,其不是对答题网友时间的及大浪费。现在这种状况可以得到改善了。本人利用空余时间写了个小程序strfmt.exe,它可以批量将上面或类似的数据一次性生成INSERT INTO # VALUES语句,如INSERT INTO # VALUES ('0001','2004-4-5','2000','3000')INSERT INTO # VALUES ('0002','2004-4-5','1000','5000')INSERT INTO # VALUES ('0003','2005-6-7','1500','3000')INSERT INTO # VALUES ('0004','2006-5-6','1200','3000')INSERT INTO # VALUES ('0005','2005-6-7','1300','3400')或者生成INSERT INTO # SELECT语句,如INSERT INTO # SELECT '0001','2004-4-5','2000','3000'INSERT INTO # SELECT '0002','2004-4-5','1000','5000'INSERT INTO # SELECT '0003','2005-6-7','1500','3000'INSERT INTO # SELECT '0004','2006-5-6','1200','3000'INSERT INTO # SELECT '0005','2005-6-7','1300','3400'有了strfmt.exe,广大答题者就能大大提高答题效率,不必浪费时间在范例数据的构建上了。 本程序只是本人业余之作,没有进行系统性的测试,希望用户能反馈出现的问题。程序存在已知问题如不能区分形如2007-11-13 12:12:00:564这种日期和时间中间有空格的字段,程序会把它们当成两个字段。在未来的改进版本中将处理这个问题。希望用户提出本程序的改进建议,本人不胜感激!联系邮箱:internetroot@hotmail.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值