文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2016-12-28 11:46

关注

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

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

整理思路

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

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

实现过程

  

  @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

 

. 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  

  

 

 

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  
@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

  

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

 

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯