相关文章推荐
直爽的红烧肉  ·  mysql查询字段中带空格的值的sql语句, ...·  3 月前    · 
深沉的黄瓜  ·  mysql基础之mariadb的安装,连接, ...·  3 月前    · 
谦逊的硬币  ·  mysql client命令行选项 - ...·  3 月前    · 
心软的夕阳  ·  解决Docker启动MySQL多实例时因共享 ...·  2 月前    · 
讲道义的烈酒  ·  Debezium-JSON--流式计算 ...·  1 周前    · 
潇洒的野马  ·  配置VScode编辑LaTeX及正反向搜索等 ...·  2 年前    · 
大方的皮蛋  ·  Delphi: how to set ...·  2 年前    · 
气势凌人的大葱  ·  JAVA使用for循环会重复调用list.s ...·  2 年前    · 
完美的黑框眼镜  ·  redis - what's the ...·  2 年前    · 
Code  ›  MySQL之source命令开发者社区
数据库 命令模式 mysql导入sql文件 mysql
https://cloud.tencent.com/developer/article/1533580
想旅行的钥匙
2 年前
作者头像
AsiaYe
0 篇文章

MySQL之source命令

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > DBA随笔 > MySQL之source命令

MySQL之source命令

作者头像
AsiaYe
发布 于 2019-11-06 15:27:29
8.3K 0
发布 于 2019-11-06 15:27:29
举报
MySQL的source命令在工作中的使用

一个线上问题的引发的思考

今天上班的时候,开发的同事拿过来一个.zip的压缩包文件,说是要把里面的数据倒入到数据库里面,本来想着是成型的SQL,只需要复制粘贴一下,倒入到数据库中就可以了。拿到的时候,才发现问题没我想的那么简单,我首先看到的是一个压缩包,大概30多M,解压之后,发现里面的内容是个.sql的数据文件,文件的大小是645M左右,这么大的文件,要是手动粘贴上去,那简直太变态了。第一反应这个是不是mysqldump出来的备份数据,要是这样的话,就可以直接在命令行中进行恢复了。于是打开看了一下里面的内容,发现这是一个标准的Navicat导出的sql文件,里面全都是各种的插入语句,到这里,一下子释然了,因为这样的就sql文件可以直接通过MySQL的source命令来倒入到数据库中,因为数据量很大,为了避免出错,我重新看了看source的语法,这里简单说明下。

MySQL之source命令

mysql source命令主要用来倒入超大的sql文件,在日常工作中,我们往往会遇到导入大的数据文件的情况,在MySQL中,用mysql source命令可以导入轻松解决这个问题,MySQL source的基本语法如下:

mysql>use dbtest;
mysql>set names utf8;
mysql>source D:/xxx/xxx/back.sql;

首先我们选定需要倒入数据的数据库,然后设定默认字符集,接着使用source命令,后面跟上我们的.sql所在的绝对路径就可以了。如果我们的文件有5个,就可以通过这样的方法一个一个倒入到数据库中,切记选定正确的数据库名称。

考虑这样一种需求,如果我们有10个这样的文件,假设手动一条一条去添加,难免出现一些错误。这时候,我们可以采用一个办法,就是把我们要写的这些source命令写在一个文件中,像下面这样:

source D:/xxx/xxx/back0.sql;
source D:/xxx/xxx/back1.sql;
source D:/xxx/xxx/back2.sql;
source D:/xxx/xxx/back3.sql;
source D:/xxx/xxx/back4.sql;
source D:/xxx/xxx/back5.sql;
source D:/xxx/xxx/back6.sql;
source D:/xxx/xxx/back7.sql;
source D:/xxx/xxx/back8.sql;
source D:/xxx/xxx/back9.sql;

然后我们去source这个文件,直接就可以顺序执行这些命令。这种方法,似乎已经解决了我们的问题,但是这样的操作方式,还存在一个新的问题,如果有100个这样的文件,而且他们的名称有一定的规律,我们一个个去写命令肯定很麻烦,这个时候我们可以通过写脚本的方式或者使用各类编辑器的列编辑模式,先产生这样一个一个的命令行,最后再一次粘贴到文件中,最终执行source命令即可。

需要注意的是,source命令执行的时候,会把query ok的命令打印到前段输入框,像下面这样:

Query ok;
Query ok;
Query ok;
Query ok;
Query ok;
 
推荐文章
直爽的红烧肉  ·  mysql查询字段中带空格的值的sql语句,并替换开发者社区
3 月前
深沉的黄瓜  ·  mysql基础之mariadb的安装,连接,用户,密码,权限设置语句详解 - Wolf_Coder
3 月前
谦逊的硬币  ·  mysql client命令行选项 - ggjucheng
3 月前
心软的夕阳  ·  解决Docker启动MySQL多实例时因共享数据卷导致的连接报错-开发者社区-阿里云
2 月前
讲道义的烈酒  ·  Debezium-JSON--流式计算 Flink版-火山引擎
1 周前
潇洒的野马  ·  配置VScode编辑LaTeX及正反向搜索等设置 - 知乎
2 年前
大方的皮蛋  ·  Delphi: how to set the length of a RTTI-accessed dynamic array using DynArraySetLength? - Stack Overflow
2 年前
气势凌人的大葱  ·  JAVA使用for循环会重复调用list.size()吗? - 知乎
2 年前
完美的黑框眼镜  ·  redis - what's the usage for trySet method in redisson rbucket - Stack Overflow
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号