【excel如何实现快速将批量数据批量生成insert语句】

本文介绍了将Excel数据转换为SQL脚本的步骤,包括在Excel中构建INSERT语句,使用公式引用单元格值,然后拖动填充至所有行,最后复制到文本文件并在数据库中执行。这种方法适用于批量数据导入的场景。
摘要由CSDN通过智能技术生成

excel技能:将Excel数据转换为SQL脚本

前言

你好! 在研发、测试工作过程中,有可能遇到需要将大批量数据导入库表的诉求,这个时候
技术方案一:就是通过编程实现;
方案二:直接利用excel软件函数实现。
下面具体介绍将Excel数据转换为SQL脚本的具体操作步骤。

步骤1

打开数据表格,将鼠标定位到第一行数据中最后一个字段后一格,如下截图中D2,在该格中输入: =“” ,在双引号中输入SQL语句,整体D2表格输入如下:
=“INSERT INTO ys_trans_document (source_id, document_type, document_id) VALUES ('”&&“', '”&&“', '”&&“');”

在这里插入图片描述

步骤2

SQL语句中,每个字段的取值要取哪一列字段,就将鼠标定位到对应位置两个&&中间,依次选择到栏位对应的单元格,如第一列的值定位到A2,这时公式里面的值就变为了&A2&,意思就是source_id的值就是A2单元格的值,第二列第三列的依次类推.

最后把鼠标光标放到公式最后面,再按Enter键,这样第一行的公式就完成了,SQL insert语句也写好了
在这里插入图片描述按enter之后:
在这里插入图片描述

步骤3

鼠标定位到所生成的第一个insert语句所在单元格,右下角出现符号:+,按住+往下拖至最后一行数据,则所有数据insert语句生成完成
在这里插入图片描述在这里插入图片描述

步骤4

选择所有的insert表格,右键单击,选择复制,粘贴到txt文件中,则所有数据的SQL脚本完成,直接在数据库执行即可
在这里插入图片描述

根据表格数据批量生成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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值