MySQL source命令的使用简介

作者:AsiaYe 时间:2024-01-15 14:35:18 

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

    今天上班的时候,开发的同事拿过来一个.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那样直接可在命令行使用。

    今天就简单写这么多吧。

来源:https://cloud.tencent.com/developer/article/1533580

标签:MySQL,source,命令
0
投稿

猜你喜欢

  • 浅谈PHP的$_SERVER[SERVER_NAME]

    2024-05-03 15:48:46
  • jQuery获取radio选中项的值实例

    2024-04-09 19:45:16
  • php实现网站留言板功能

    2023-11-23 21:06:36
  • 绘制微信小程序验证码功能的实例代码

    2024-04-17 10:30:28
  • MySQL 原理与优化之原数据锁的应用

    2024-01-27 05:43:51
  • 一看就懂的MySQL的聚簇索引及聚簇索引是如何长高的

    2024-01-17 22:31:24
  • 总结Python函数参数的六种类型

    2021-12-21 02:55:56
  • Python使用psutil对系统数据进行采集监控

    2023-03-13 07:21:19
  • 详解Python 装饰器执行顺序迷思

    2023-12-30 23:55:23
  • 深入理解Django的自定义过滤器

    2021-01-25 04:01:54
  • Python解释器及PyCharm工具安装过程

    2021-02-23 08:21:51
  • 聊聊通过celery_one避免Celery定时任务重复执行的问题

    2021-05-20 13:19:12
  • python爬虫系列Selenium定向爬取虎扑篮球图片详解

    2021-02-19 17:21:52
  • SQL Server索引设计基础知识详解使用

    2024-01-19 01:11:31
  • sqlserver2005自动创建数据表和自动添加某个字段索引

    2024-01-26 19:37:17
  • Unity连接MySQL并读取表格数据的实现代码

    2024-01-19 05:20:30
  • python数据可视化Seaborn绘制山脊图

    2023-12-22 09:04:17
  • python 快速排序代码

    2022-04-15 00:00:21
  • Python绘制组合图的示例

    2023-07-30 01:34:31
  • Python中使用socket发送HTTP请求数据接收不完整问题解决方法

    2021-06-29 11:43:50
  • asp之家 网络编程 m.aspxhome.com