insert into用法(1.批量新增,2.复制)

本文详细介绍了SQL中进行数据插入的方法,包括单条记录插入、批量插入及从其他表复制数据等场景,并给出了具体示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.新增数据

insert into tableName set columnName1 = value1,columnName2 = value2,…;

1.新增Or批量新增:

insert into tableName values (value1,value2,…),(xxx,xxx,…),…;

insert into tableName(column1,column2,…) values (value1,value2,…),(xxx,xxx,…),…;

2.复制:

(1) insert into tableName1 select * from tableName2;(没主键)

(2) insert into tableName(id, columnName1,columnName2,…) select 'XXX' as id, column1,column2 ,… from tableName2;(有主键:UUID)

(3) insert into tableName(columnName1,columnName2,…) select column1,column2 ,… from tableName2;(有主键:自增)


根据表格数据批量生成Insert Into语句 本人在登陆优快云论坛的数据库板块时,常看到很多网友提关于数据库的各种问题。而这些问题中有很多是要使用范例数据的。但是很多提问的朋友却没有把这些范例数据库的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
### SQL Insert Into Values 和 批量 Insert 的性能对比及适用场景 #### 单条插入的性能特点 单条 `INSERT` 语句通常用于每次只向表中插入一条记录的情况。其语法结构如下所示: ```sql INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...); ``` 由于每执行一次该语句都会触发单独的日志写入、索引更新以及可能的锁机制,因此频繁调用会显著增加开销[^1]。 #### 批量插入的性能优势 相比之下,批量插入允许通过单一SQL命令完成多个行的数据加载工作。这不仅减少了网络往返次数,还降低了事务管理成本并提高了整体吞吐率。具体实现方式可以采用Oracle中的多值列表方法或者利用其他数据库支持的大规模导入工具和技术。例如,在某些情况下,“合并+事务+有序数据”的策略能够极大提升效率[^2]。 以下是基于实验得出的一些结论关于如何提高插入操作的速度: - 使用显式事务控制减少自动提交带来的额外负载; - 将待处理的数据预先排序以便更好地配合现有B树索引结构; - 如果目标环境允许,则考虑临时禁用外键约束和非必要索引来加速过程后再恢复它们的状态。 对于实际应用而言,当面对大量连续性新纪录加入需求时(比如日终汇总报表生成),显然批量化方案更为合适;而针对零散新增业务逻辑下的个别对象创建动作来说,逐项录入不失为一种简单直观的选择[^3]。 ```sql -- Oracle 中的一次性插入多条记录示例 INSERT ALL INTO my_table (colA,colB) VALUES ('val1','val2') INTO my_table (colA,colB) VALUES ('val3','val4') SELECT * FROM dual; ``` #### 技术选型建议 在决定采取何种方式进行数据存储之前,应当综合考量以下几个方面因素: - 数据源特性:如果源头本身就具备批次特征或者是文件形式存在的话,那么优先选用后者无疑更加合理高效。 - 应用程序架构设计:考虑到前后端交互模式差异可能会对最终决策造成影响。 - 系统资源状况评估:包括但不限于CPU利用率水平、内存剩余空间大小等因素均需纳入权衡范围之内。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值