如何用Excel快速生成SQL语句,用过的人都说好

640?wx_fmt=gif

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

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


作者:丶平凡世界
来源:SQL数据库开发(ID:sql_road)

01 导入Excel数据

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

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

640?wx_fmt=png

02 写好模板语句

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

INSERT INTO Person VALUES(1,'吕布',25,'男','13500000001')

然后复制这条SQL语句打开Excel,选中表格后的一个单元格,在上方函数位置粘贴刚才的SQL语句并做修改。

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

640?wx_fmt=png

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

03 生成SQL语句

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

640?wx_fmt=png

04 执行SQL

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

640?wx_fmt=png

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

640?wx_fmt=png

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

05 扩展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;

06 套用Excel生成SQL方法

但是如果是新手同学,不会写上面的代码,而此时又要我们做这样的事怎么办呢?就可以使用上面的方法了。

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

SELECT TABLE_NAME FROM user_tables

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

640?wx_fmt=png

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

640?wx_fmt=png

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

640?

有话要说?

Q:   Excel还有哪些神应用?
欢迎留言与大家分享

猜你想看?

更多精彩?

在公众号对话框 输入以下 关键词
查看更多优质内容!

PPT  |  报告  |  读书  |  书单  |  干货  
大数据  |  揭秘  |  Python  |  可视化
AI  |  人工智能  |  5G  |  区块链
机器学习  |  深度学习  |  神经网络
合伙人  1024  |  段子  |  数学  |  高考

据统计,99%的大咖都完成了这个神操作
?

640?wx_fmt=png

觉得不错,请把这篇文章分享给你的朋友
转载 / 投稿请联系:baiyu@hzbook.com
更多精彩,请在后台点击“历史文章”查看
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值