【已解决】MySQL(Navicat)中如何一次性执行多个sql脚本文件
创始人
2025-01-15 22:33:47
0

目录

问题现象:

问题分析:

思路:

解决方法:

        1、运行cmd命令窗口

        2、执行文本文件内容合并命令

总结:

        1、使用文本文件内容合并命令,将多个sql脚本文件的内容合并到一个新的sql文件中去。

        2、然后在Navicat中打开对应数据库,运行该合并后的sql脚本文件即可。


问题现象:

        今天在项目中遇到一个问题,有一个同事导出了项目A用到的所有数据库的所有表的sql文件(没有根据数据库分开存放,而是全部放在了同一个文件夹中),然后需要我按照sql文件前缀(前缀就是数据库名)来导入到项目B中对应的数据库去,sql文件如下:


        所以就引出了本文的标题:

        MySQL中如何一次性执行多个sql脚本文件?


问题分析:

        当时接到这个任务,第一时间想到的就是:

        在Navicat中在对应的数据库下,运行sql文件皆可:

        但是感觉这样的一个文件一个文件地运行效率实在太低了,会浪费很多时间啊!因为同事给我的sql脚本文件压缩包里面有近200个sql文件。

        于是我就去查资料,想看看Navicat中是否有点击一次按钮就能批量运行多个sql文件的功能?

        很遗憾,我用的Navicat15没有这个功能!那估计Navicat目前应该是不支持这种一次性运行多个sql文件的功能。

        那该如何是好?难道我真的要用最笨的方法:一个文件一个文件地去运行?

        不信邪的我,再次上网查资料,最后发现了一个也很方便的方法,非常好的解决了我的问题!


思路:

        既然Navicat中不支持一次性运行多个sql文件,那有没有办法可以把所有的sql文件中的sql都归纳到同一个汇总的sql文件去,然后在Navicat中运行这个汇总的sql文件不就可以了吗!!!

        那就只需要查一下文本文件内容合并的命令就可以了。


        很快我就查到了Windows系统中实现文本文件内容合并的命令,如下:

type 指定需要合并的文件 >>合并后的文件名

        当然这里如果追求更高效率的话,建议学习一点文件检索相关的基础命令知识,因为我希望可以有命令能帮我检索出我需要合并的文件;因为我这200多个sql文件都来自于不同的数据库,我需要根据sql文件名的前缀,去检索出我在每个数据库中对应的需要用到的文件,然后将他们合并到一个sql文件中去,然后再去Navicat中对应的数据库执行这个合并后的sql文件即可。

        至此,就相当于间接地解决了本文开头提出的问题!

        然后由于数据库不同,不可能在一个数据库下去执行所有的sql脚本文件,所以需要根据对应的数据库名来检索对应的文件并生成对应的sql合并文件才行;但一般的项目中用到的数据库基本都不会超过20个。


解决方法:

        1、运行cmd命令窗口

        在200多个sql脚本文件所在目录中打开cmd命令窗口(直接在地址栏输入cmd然后按下enter键即可):

        2、执行文本文件内容合并命令

        在打开的cmd窗口中执行命令如下:

type app_hp_*.sql >>app_hp.sql

        意思是把所有文件名前缀为【app_hp_】的文本文件的内容都合并到一个新文件【app_hp.sql】中:

        此时可以看到红框中的文件就是本次匹配到的sql文件,然后在当前文件目录下会生成了一个新的文件,即我们合并操作后的新文件【app_hp.sql】:

        最后就是在Navicat中,根据数据库执行对应的sql文件即可:

        执行完就能看见刚才匹配到的那3个sql脚本文件对应的表了:

总结:

        目前我还未找到MySQL(Navicat)中一次性执行多个sql脚本文件的直接解决方法,但是找到了间接的解决方法:

        1、使用文本文件内容合并命令,将多个sql脚本文件的内容合并到一个新的sql文件中去。

        2、然后在Navicat中打开对应数据库,运行该合并后的sql脚本文件即可。

相关内容

热门资讯

透视普及!微乐小程序黑科技(外... 透视普及!微乐小程序黑科技(外挂),微乐小程序有脚本,教程机巧(有挂攻略)-哔哩哔哩1、每一步都需要...
有了最新消息!微乐小程序黑科技... 有了最新消息!微乐小程序黑科技,微乐陕西小程序辅助(作弊器)窍要教程(本来真的有挂)1)辅助插件:进...
随着!aapoker辅助怎么用... 随着!aapoker辅助怎么用,悦扑克脚本,操作教程(有挂技术)-哔哩哔哩1、进入到aapoker辅...
透视苹果版!微乐小程序黑科技,... 透视苹果版!微乐小程序黑科技,微信小程序微乐破解器(透视)竟然是有挂(有挂详细)-哔哩哔哩1、不需要...
透视揭露!微乐小程序黑科技(外... 透视揭露!微乐小程序黑科技(外挂),微乐多乐跑作弊,教程技法(有挂助手)-哔哩哔哩1、任何透视是真的...
最新消息!微乐小程序免费黑科技... 最新消息!微乐小程序免费黑科技,微信小程序微乐游戏修改器(作弊器)模板教程(都是存在有挂)1、许多玩...
出乎意料的是!玉海楼茶苑怎么开... 出乎意料的是!玉海楼茶苑怎么开挂,新畅游互娱科技,要领教程(竟然有挂)-哔哩哔哩1、起透看视 玉海楼...
透视计算!微乐小程序黑科技,微... 透视计算!微乐小程序黑科技,微乐小程序真的有挂(透视)其实真的有挂(有挂细节)-哔哩哔哩所有人都在同...
透视必备!微乐小程序免费黑科技... 透视必备!微乐小程序免费黑科技(外挂),微乐自建房脚本入口,教程总结(果真有挂)-哔哩哔哩1、打开软...
这一问题亟待解决!微乐小程序免... 这一问题亟待解决!微乐小程序免费黑科技,微乐自建房脚本免费入口(作弊器)步骤教程(原来是真的挂)1、...