使用Excel批量生成SQL语句,用过的人都说好

Excel批量生成SQL语句
原文链接:https://blog.csdn.net/2401_89368762/article/details/144972349

Excel的公式自动生成想必大家都知道了,就是写好一个公式后直接往下拖,就可以将后面数据的公式自动生成。

今天我们就用这个功能来快速生成SQL语句。

导入Excel数据
Excel的数据有多种方式,这里我们演示用SQL代码导入Excel中的数据。

例如我们想把左边Excel中的数据插入到数据库中,如下图:

 

写好模板语句
我们可以先写一条插入语句,如下:

INSERT INTO Person VALUES(1,'吕布',25,'男','13500000001')
1
然后复制这条SQL语句打开Excel,选中表格后的一个单元格,在上方函数位置粘贴刚才的SQL语句并做修改,

="INSERT INTO Person VALUES("&A2&",'"&B2&"',"&C2&",'"&D2&"','"&E2&"')"
1


注意前面有个= 然后整个SQL用 ""包围住。

生成SQL语句
确认后就可以看到在单元格中会自动生成一条SQL语句。选中单元格下拉,会发现所有的行后面都会生成一条SQL语句。

 

执行SQL
然后我们直接复制这些SQL语句到数据库的查询窗口执行。

 

执行完后我们查询Person表里的数据。

 

这样就完成了Excel快速生成SQL语句的功能。

扩展SQL示例
以上只是一个简单的示例,运用这种方法我们还可以自动生成很多其他的SQL脚本,比如要查询数据库中所有表中的记录数。

当然我们可以使用循环遍历系统中的所有表然后再用循环语句执行指定的语句,如下:

--使用循环语句查询所有表的数量
DECLARE
TNAME VARCHAR2(200);
BEGIN
--获取系统表中的所有表名
FOR X IN (SELECT TABLE_NAME FROM user_tables where table_name like 'HR_TEMPTABLE%')
--开始循环
LOOP
--循环主体部分

TNAME :=X.TABLE_NAME; --赋值
EXECUTE IMMEDIATE 'SELECT '''X.TABLE_NAME'''||',COUNT(1) Num FROM '||X.TABLE_NAME; --执行循环主体
END LOOP;
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.put_line(TNAME);
RAISE;
END;
END;
套用Excel生成SQL方法
但是如果是新手同学,不会写上面的代码,而此时又要我们做这样的事怎么办呢?就可以使用上面的方法了。

可以先从系统表中查询出所有的表名

SELECT TABLE_NAME FROM user_tables
将表名复制粘贴到Excel中,然后开始写查询语句,如下图:

 

然后将这些代码复制粘贴到查询窗口即可查询出所有表中的记录数了。

 

使用此方法还可以应用在很多类似的场景,他们的共同点就是代码结构一样,但是代码中的参数不一样,对于想快速写出相应的SQL代码是非常有效的。

 

posted on   大西瓜3721  阅读(122)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
历史上的今天:
2023-02-14 SqlServer资料
2016-02-14 c#里BindingFlags 筛选标志
2016-02-14 [C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例
2016-02-14 玩转Asp.net MVC 的八个扩展点
2016-02-14 float实例讲解

导航

点击右上角即可分享
微信分享提示