服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL执行外部sql脚本文件的命令

MySQL执行外部sql脚本文件的命令

2022-02-12 19:58ReaderWriter Mysql

sql脚本是包含一到多个sql命令的sql语句,我们可以将这些sql脚本放在一个文本文件中,然后通过相关的命令执行这个sql脚本文件,本文就详细的介绍一下,感兴趣的朋友可以了解一下

sql脚本是包含一到多个sql命令的sql语句,我们可以将这些sql脚本放在一个文本文件中(我们称之为“sql脚本文件”),然后通过相关的命令执行这个sql脚本文件。

1.创建包含sql命令的sql脚本文件

在d盘根目录下新建一个文本文档,并改名为day01.sql(名字自己取,最好不要有中文,特殊符号,以.sql结尾)

MySQL执行外部sql脚本文件的命令

day01.sql文件中包含一些列的sql语句,每条语句最后以;结尾,文件内容示例如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
create table emps (
    empno       int(8)  primary key,
    ename       varchar(20),
    job         varchar(20),
    mgr         int(8),
    hiredate    date,
    sal         double(11,2),
    comm        double(11,2),
    deptno      int(8)
);
  
insert into emps values(1,'张三','领导',0,sysdate(),18000.0,3000.0,1);
insert into emps values(2,'李四','销售',1,sysdate(),7000.0,5000.0,1);
insert into emps values(3,'王五','销售',1,sysdate(),8000.0,2000.0,1);
insert into emps values(4,'马六','市场',1,sysdate(),6000.0,0,1);
insert into emps values(5,'周七','市场',1,sysdate(),5000.0,0,1);
insert into emps values(6,'冯八','市场',1,sysdate(),4000.0,0,1);
commit;

MySQL执行外部sql脚本文件的命令

需要注意的是,mysql里不能直接创建序列create sequence,需要创建一张储存sequence的表,然后手动插入一条数据 ,最后自定义一个函数来处理要增长的值。

以上sql语句中包含中文,所以,在执行sql脚本文件前,需要检查一下你现在使用的mysql使用的是什么字符集。 mysql中默认字符集的设置有四级:服务器级,数据库级,表级 。最终是字段级 的字符集设置。注意前三种均为默认设置,并不代码你的字段最终会使用这个字符集设置。所以我们建议要用show create table tablename ;show full fields from tablename; 来检查当前表中字段的字符集设置。

mysql中关于连接环境的字符集设置有 client端,connection, results ,通过这些参数,mysql就知道你的客户端工具用的是什么字符集,结果集应该是什么字符集。这样mysql就会做必要的翻译,一旦这些参数有误,自然会导致字符串在转输过程中的转换错误。基本上99%的乱码由些造成。

当前联接系统参数  show variables like 'char%';

MySQL执行外部sql脚本文件的命令

退出mysql,使用net stop mysql命令,停止mysql服务

找到你的mysql安装目录下,找到my.ini文件,用记事本打开

MySQL执行外部sql脚本文件的命令

MySQL执行外部sql脚本文件的命令

重新打开cmd控制台,输入net start mysql回车,启动mysql服务,启动成功后,进入mysql,并使用jsd170101数据库

MySQL执行外部sql脚本文件的命令

2.执行sql脚本文件(介绍三种方式)

方法一:

c:\users\administrator>mysql -uroot -p123456 -djsd170101<d:\day01.sql
//mysql -u账号 -p密码 -d数据库名 < sql文件绝对路径

MySQL执行外部sql脚本文件的命令

MySQL执行外部sql脚本文件的命令

方法二:

mysql> source d:\day01.sql   
//mysql控制台下执行source d:\day01.sql

MySQL执行外部sql脚本文件的命令

方法三:

mysql> \. d:\day01.sql 
// \. d:\day01.sql

MySQL执行外部sql脚本文件的命令

到此这篇关于mysql执行外部sql脚本文件的命令的文章就介绍到这了,更多相关mysql执行外部sql内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/czbqoo01/article/details/70037987

延伸 · 阅读

精彩推荐