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

Wesley13
• 阅读 959

起因: 因工作需要,在本机测试环境升级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   )

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

  • 将creatsql.bat放在sql文件所在目录。执行bat文件后,会得到batch.sql文件。生成的文件内容如下:

    . D:\gzkj\mysql\patchScipt\4.7.25\aa.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\bb.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\cc.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\dd.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\ee.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\ff.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\gg.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\hh.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\ii.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:\gzkj\mysql\patchScipt\4.7.25\aa.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\bb.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\cc.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\dd.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\ee.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\ff.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\gg.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\hh.sql
    . D:\gzkj\mysql\patchScipt\4.7.25\ii.sql

  • 最后需要编写升级这些sql所需的bat脚本,脚本如下:

    @echo off :: 指定MySQL安装路径 C: cd C:\Program Files\MySQL\MySQL Server 5.6\bin :: 数据库名称 @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版本】

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

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

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
3年前
sql注入
反引号是个比较特别的字符,下面记录下怎么利用0x00SQL注入反引号可利用在分隔符及注释作用,不过使用范围只于表名、数据库名、字段名、起别名这些场景,下面具体说下1)表名payload:select\from\users\whereuser\_id1limit0,1;!(https://o
Stella981 Stella981
3年前
Excel数据转化为sql脚本
在实际项目开发中,有时会遇到客户让我们把大量Excel数据导入数据库的情况。这时我们就可以通过将Excel数据转化为sql脚本来批量导入数据库。1在数据前插入一列单元格,用来拼写sql语句。 具体写法:"insertintot\_student(id,name,age,class)value("&B2&",'"&C2&"',"&D2&"
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
3年前
MYSQL基础知识小盲区
MYSQL必会的知识新学的MySQL小技能:show PROCESSLIST; 查看当前数据库的进程(也就是正在进行的sql操作)!(https://oscimg.oschina.net/oscnet/c7908995a15dcf322850eb4ba0416cc34b1.png)kil
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
thinkphp 基本配置
12returnarray(34//定义数据库连接信息5'DB\_TYPE''mysql',//指定数据库是mysql67'DB\_HOST''localhost',89'DB\_NAME''uchome',//数据库名1011'DB\_USER''root
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究