数据库学习 - insert into(批量添加)

数据新增insert命令有两种形式

1 单一数据新增:

Inset into 表名 [(列名[,列名]...)]

Values ([,]...);

这种形式可以向数据库中插入一条数据,也可以利用这种形式在数据库中插入多条黄数据;

Inset into 表名 [(列名[,列名]...)]

Values ([,]...),([,]...),([,]...),([,]...)...;

2 批量数据新增:

插入子查询结果中的若干条数据,待插入的数据由子查询给出;

Inset into 表名 [(列名[,列名]...)]

子查询;

示例:

新建tablest(student_id,student_name),将查询到的姓张的同学添加到该表中

INSERT INTO st (student_id, student_name) SELECT
	student_id,
	student_name
FROM
	student
WHERE
	student_name LIKE '张%' ;

注意:当新增数据时,DBMS会检查用户定义的完整性约束条件,如不符合完整性约束条件,则将不会执行新增动作。

根据表格数据批量生成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
回答: 批量插入数据可以使用多种方法。一种方法是使用INSERT INTO语句,按照以下语法格式进行操作:insert into +表名(表中的字段,,)values(字段所对应的记录,,)(字段所对应的记录); INSERT INTO table_name VALUES (value1,value2,value3,…),(value1,value2,value3,…); 用逗号隔开,括号括起来,加多少行数据就写多少个。\[1\]另一种方法是将另一张表的内容插入本表中,可以使用以下语法:INSERT INTO \[数据库名\].\[dbo\].\[表1\](\[序号\],\[字段2\]) select \[序号\],\[字段2\] from \[数据库名\].\[dbo\].\[表2\] where 序号 ='1'。\[2\]还有一种方法是使用SELECT语句将符合条件的数据插入到目标表中,例如:INSERT INTO st (student_id, student_name) SELECT student_id, student_name FROM student WHERE student_name LIKE '张%'。\[3\]这些方法都可以实现批量插入数据的操作。 #### 引用[.reference_title] - *1* *2* [插入数据库 insert into 语句的三种写法 (附批量插入)](https://blog.csdn.net/mt_187/article/details/118979341)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [数据库学习 - insert into(批量添加)](https://blog.csdn.net/linan_pin/article/details/70159205)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值