mysql数据库批量执行sql文件对数据库进行操作【windows版本】「建议收藏」

mysql数据库批量执行sql文件对数据库进行操作【windows版本】「建议收藏」起因: 因工作需要,在本机测试环境升级mysql数据库,需逐条执行mysql数据库的sql文件对数据库进行升级,因此找了些关于mysql的文章,对批量升级数据库所需的sql文件进行升级。 整理思路:

mysql数据库批量执行sql文件对数据库进行操作【windows版本】

起因: 因工作需要,在本机测试环境升级mysql数据库,需逐条执行mysql数据库的sql文件对数据库进行升级,因此找了些关于mysql的文章,对批量升级数据库所需的sql文件进行升级。

整理思路

  1. 首先,需要对所需升级的sql所在目录的sql文件进行遍历。生成新的批量执行sql文件。想到是windows系统安装的mysql,首先想到使用bat进行sql文件的生成;
  2. 生成sql文件后,还需要使用bat文件连接到数据库,并使用新生成的sql文件进行升级。
  3. 想到升级的过程中还有可能字符集出现问题,因此需要使用cmd登陆mysql控制台,对编码进行查看。如编码格式不正确,还需调整编码格式。

  因此,需对这些思路进行实践验证。验证后,整理出操作过程,分享给广大猿友。

实现过程

  • 遍历文件并生成sql文件的 bat脚本文件如下:

  

  @echo off & setlocal EnableDelayedExpansion 
  @set source=.
  for /f "delims=" %%i in (""dir /a/s/b/on *.sql"") do ( 
    set file=%%~fi 
    set file=!file:/=/! 
    echo .
    echo %source% !file! >> batch.sql
  )

代码100分

 

  将上方的bat脚本,粘贴到txt文件中,并重命名,这里重命名为: creatsql.bat

 

  • 将creatsql.bat放在sql文件所在目录。执行bat文件后,会得到batch.sql文件。生成的文件内容如下:
代码100分. D:gzkjmysqlpatchScipt4.7.25aa.sql     
. D:gzkjmysqlpatchScipt4.7.25b.sql     
. D:gzkjmysqlpatchScipt4.7.25cc.sql     
. D:gzkjmysqlpatchScipt4.7.25dd.sql     
. D:gzkjmysqlpatchScipt4.7.25ee.sql     
. D:gzkjmysqlpatchScipt4.7.25ff.sql     
. D:gzkjmysqlpatchScipt4.7.25gg.sql     
. D:gzkjmysqlpatchScipt4.7.25hh.sql     
. D:gzkjmysqlpatchScipt4.7.25ii.sql  

  • 分析执行文件可能会存在编码格式不正确的问题,因此在CMD窗口执行查看数据库编码格式如下:

  mysql数据库批量执行sql文件对数据库进行操作【windows版本】「建议收藏」

 

 

  •  查看到有字符集编码格式不正确,因此需要调整字符集编码格式,调整的编码格式的配置放在新生成的batch.sql文件内,然后batch.sql文件如下:
set character_set_client=utf8;
set character_set_connection=utf8;
set character_set_results=utf8;
. D:gzkjmysqlpatchScipt4.7.25aa.sql     
. D:gzkjmysqlpatchScipt4.7.25b.sql     
. D:gzkjmysqlpatchScipt4.7.25cc.sql     
. D:gzkjmysqlpatchScipt4.7.25dd.sql     
. D:gzkjmysqlpatchScipt4.7.25ee.sql     
. D:gzkjmysqlpatchScipt4.7.25ff.sql     
. D:gzkjmysqlpatchScipt4.7.25gg.sql     
. D:gzkjmysqlpatchScipt4.7.25hh.sql     
. D:gzkjmysqlpatchScipt4.7.25ii.sql  

  • 最后需要编写升级这些sql所需的bat脚本,脚本如下:
代码100分@echo off
:: 指定MySQL安装路径
C:
cd C:Program FilesMySQLMySQL Server 5.6in
:: 数据库名称
@set db=dbname
:: 用户名
@set userName=username
:: 密码
@set password=aaa123456
:: 获取文件夹所在绝对路径
@set basePath=%~dp0
:: 要执行的sql脚本
@set sqlpath=%basePath%batch.sql
:: 连接MySQL数据库并执行sql脚本 -f 脚本执行过程中,出现错误继续执行 --default-character-set指定导入数据的编码(与数据库编码相同)
mysql -f -u %userName% --password=%password% %db% < %sqlpath% --default-character-set=gbk
:: 执行完成后,不立刻关闭dos窗口
pause

  • 将上方bat脚本内容放在txt文件中,重命名,这里重命名为:update.bat,然后将update.bat同样放在sql所在目录下,点击执行update.bat文件,执行结果如下:

  mysql数据库批量执行sql文件对数据库进行操作【windows版本】「建议收藏」

  • 可以看到,这里有执行报错的信息,证明批量执行是可以的。

  谨以此文分享给大家,相信也能够帮到想要如此操作,却无从下手的同仁们。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/9887.html

(0)
上一篇 2023-01-30 13:00
下一篇 2023-01-30

相关推荐

  • 数据库备份、还原、删除、收缩,创建登录用户,数据库用户等操作脚本「建议收藏」

    数据库备份、还原、删除、收缩,创建登录用户,数据库用户等操作脚本「建议收藏」记录一下/ –备份数据库 use [master] go BACKUP DATABASE [LnkSys11] TO DISK = N'C:BackUpLnkSys11.bak'

    2022-12-25
    143
  • Python连接Oracle示例

    Python连接Oracle示例Python是一门强大的编程语言,对于数据分析和数据处理有着广泛的应用。而Oracle是企业级数据库中的佼佼者之一,其数据存储和管理能力得到了广泛的认可。将Python和Oracle相结合可以为用户提供更大范围的应用场景,因此Python连接Oracle成为了一个值得探讨的话题。

    2024-05-29
    79
  • 浅析 path 常用工具函数源码

    浅析 path 常用工具函数源码在开发过程中,会经常用到 Node.js ,它利用 V8 提供的能力,拓展了 JS 的能力。而在 Node.js 中,我们可以使用 JS 中本来不存在的 path 模块

    2023-03-02
    146
  • 如何在Linux中修改文件夹名称

    如何在Linux中修改文件夹名称在Linux系统中,修改文件夹名称是一个常见的操作。有时候,我们需要更改文件夹名称以使其更具有显著的性质或更方便查找。这篇文章将深入探讨如何在Linux中修改文件夹名称。

    2024-07-07
    49
  • 那些你不知道的 TCP 冷门知识[亲测有效]

    那些你不知道的 TCP 冷门知识[亲测有效]最近在做数据库相关的事情,碰到了很多TCP相关的问题,新的场景新的挑战,有很多之前并没有掌握透彻的点,大大开了一把眼界,选了几个案例分享一下。 案例一:TCP中并不是所有的RST都有效 背景知识:在…

    2023-04-14
    159
  • mysql使用b+树的原因_b+树索引和hash索引

    mysql使用b+树的原因_b+树索引和hash索引https://www.jianshu.com/p/7ce804f97967 众所周知,MySQL的索引使用了B+树的数据结构。那么为什么不用B树呢? 先看一下B树和B+树的区别。 1.B树 维基百科

    2023-02-21
    858
  • MySQL 常用操作语句「建议收藏」

    MySQL 常用操作语句「建议收藏」数据库安装,待完善 https://www.cnblogs.com/wendy-0901/p/12673705.html https://blog.csdn.net/yougoule/article…

    2023-04-09
    163
  • Python中Callable的概念与实现

    Python中Callable的概念与实现在Python的世界中,我们常常会听到关于callable的概念。那么”callable”是什么呢?在Python中,callable是指一种特殊的对象,这种对象可以像函数一样”callable”或被调用,例如Python中的函数、方法、类以及实现了特殊方法__call__的对象。在本文中,我们将会详细介绍callable的概念、使用场景以及具体实现等方面的内容。

    2024-04-20
    72

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注