暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

SQL数据库开发 2019-09-07
346

点击上方SQL数据库开发,关注获取SQL视频教程


SQL专栏

SQL数据库基础知识汇总

SQL数据库高级知识汇总

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


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


导入Excel数据

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

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


写好模板语句

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

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



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

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


      注意前面有个= 然后整个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代码是非常有效的。


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

          更多推荐
          如何机智的弄坏一台电脑?来自一名前端工程师的报复...
          面试官:说说自增主键用完了怎么办?
          没在路边改过代码的程序员,不足以谈人生
                 

          微信内回复1,拉你进微信交流群 

          长按下方二维码,和大家一起练SQL

          点击"阅读原文",了解SQL训练营

          文章转载自SQL数据库开发,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

          评论