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

转载来自51cto:https://blog.51cto.com/15057820/2653376

SQL专栏

SQL数据库基础知识汇总

SQL数据库高级知识汇总

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

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

导入Excel数据

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

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

2b629274c3142298542731ae3156044f.png

写好模板语句

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

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

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

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

8a22d252cb9c56aaaa8fdf50dbdb1efc.png

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

生成SQL语句

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

1d594d0ec19fe31c53a79712b1091c2b.png

执行SQL

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

e38dc9f509b3836897580406be617237.png

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

662ab445cad85b0706d3a4a382372f02.png

这样就完成了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中,然后开始写查询语句,如下图:

a63b18c4e616781673706ad885bcd2af.png

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

1d6df4dca37ef2ac9e330bba0e62430a.png

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

觉得不错,欢迎转发分享给更多人~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值