mysqlsource命令作用(MySQL source命令的使用简介)
mysqlsource命令作用
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; query ok; query ok; query ok; |
如果不想看到这样的结果,可以将source命令的输出结果重定向到一个文件中,这样就可以避免不停的在控制台输出了。
|
mysql>use db_test mysql>source d:/test.sql > output .log |
最后提醒一点,source命令需要在mysql命令行中使用,而不像mysqldump那样直接可在命令行使用。
今天就简单写这么多吧。
以上就是mysql source命令的使用简介的详细内容,更多关于mysql source命令的使用的资料请关注开心学习网其它相关文章!
原文链接:https://cloud.tencent.com/developer/article/1533580
- linuxmysql安装教程5.7.25学习(linux mysql5.5升级至mysql5.7的步骤与踩到的坑)
- MySQL中使用mysqldump命令备份
- mysqlinnodb有什么功能(Mysql技术内幕之InnoDB锁的深入讲解)
- mysql客户端怎么运行程序(MySQL 如何连接对应的客户端进程)
- laravel mysql 操作方式(Laravel使用原生sql语句并调用的方法)
- mysql删除表内所有数据(mysql 大表批量删除大量数据的实现方法)
- 图片如何存放在mysql中(将图片保存到mysql数据库并展示在前端页面的实现代码)
- mysql为啥使用b+树(MySQL用B+树作为索引结构有什么好处)
- mysql重启启动失败(MySQL8.0无法启动3534的解决方法)
- mysql的uuid说明(MySQL GTID全面总结)
- mysql自增主键创建过程(深入谈谈MySQL中的自增主键)
- 合理设置服务mysql最大连接数(MySQL正确修改最大连接数的3种方案)
- mysql中FIND_IN_SET函数
- 升级mysql客户端版本(超详细教你怎么升级Mysql的版本)
- mysql自定义函数怎么设置(MySQL自定义变量?学不废不收费~)
- mysql查看死锁记录(mysql查看死锁与去除死锁示例详解)
- 直播带货能赚到很多钱吗(直播带货能赚到很多钱吗现在)
- 做网红真的很能赚钱吗(做网红真的很能赚钱吗)
- 10句英语常用(英语常用900句)
- 爱情能当饭吃吗(爱情能当饭吃吗说说)
- 白T恤穿法(白t恤)
- 你怎么忘了是说先爱我(你怎么忘了如何爱我)
热门推荐
- css3支持多重背景吗(真正了解CSS3背景下的@font face规则)
- iframe嵌入页面跨域(使用iframe+postMessage实现页面跨域通信的示例代码)
- 面试时在坐姿上应该注意什么
- react定时任务(手把手带你用React撸一个日程组件)
- mysqldump导入导出(MySQL官方导出工具mysqlpump的使用)
- sqlserver列数据拆分(SQL Server基础之行数据转换为列数据)
- 如何把阿里云盘加入到快捷操作(阿里云如何挂载数据盘?阿里云挂载数据盘一键脚本)
- php微信支付流程(PHP实现微信退款的方法示例)
- .NET中比较实用的开发工具
- docker容器启动失败怎么查找原因(解决docker安装后运行hello-world报错的问题)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9