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
- mysql字符类型长度限制
- mysql慢日志查询作用(MySQL 慢查询日志的开启与配置)
- 设置mysql字符集语句(MySQL修改字符集的实战教程)
- mysql数据库数据分析(详解MySQL数据库千万级数据查询和存储)
- django操作默认数据库(Django数据库类库MySQLdb使用详解)
- mysql的null值跟空值(你知道mysql中空值和null值的区别吗)
- mysql8.0.26安装教程(mysql 8.0.22压缩包完整安装与配置教程图解亲测安装有效)
- mysql是自动commit吗(详解MySQL与Spring的自动提交autocommit)
- mysql8.0.15安装详细教程(Mysql8.0.22解压版安装教程小白专用)
- mysql流式查询(MySQL全面瓦解之查询的正则匹配详解)
- mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)
- oracle和mysql查询所有表(Oracle、MySQL和SqlServe三种数据库分页查询语句的区别介绍)
- mysql查询killed状态的进程(MySQL kill指令使用指南)
- mysql模糊查询语句(mysql中like % %模糊查询的实现)
- mysql8.0.23的安装步骤(mysql 8.0.22 下载安装配置方法图文教程)
- idea怎样连接mysql(IDEA配置连接MYSQL数据库遇到Failed这个问题解决)
- 2020年大众7.5代高尔夫R终结特别版 最后的呐喊(2020年大众7.5代高尔夫R终结特别版)
- 七年前的这部剧有毒,全剧只有女主红到发紫,男主至今无人认识(七年前的这部剧有毒)
- 宋轶除了演过于曼丽,原来还演过一个青楼女子(宋轶除了演过于曼丽)
- 赵丽颖第一部当女主的戏,主角配角个个都是实力演员(赵丽颖第一部当女主的戏)
- 乾隆为何这么喜爱白塔原因是什么(乾隆为何这么喜爱白塔原因是什么)
- 逐渐消失的东北八大怪现象,进步的社会里我们遗失的是什么(逐渐消失的东北八大怪现象)
热门推荐
- mysql中json的支持(MySQL中json字段的操作方法)
- 宝塔面板密码忘记了怎么解锁(宝塔面板忘记用户名密码怎么找回)
- MongoDB聚合函数
- apache服务部署tomcat(详解Apache 和 Tomcat 整合原理、配置方案)
- 使用vue-cli构建electron项目(MAC+PyCharm+Flask+Vue.js搭建系统)
- css下填充代码(CSS学习笔记之常用Mixin封装实例代码)
- dedecms授权付费(dedecms实现删除垃圾会员的方法)
- python人脸识别库(20行python代码实现人脸识别)
- django常用模块(django celery redis使用具体实践)
- sql如何把现有字段设为notnull(在SQL中该如何处理NULL值)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9