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

 更新时间:2021年12月22日 10:18:36   作者:ReaderWriter  
sql脚本是包含一到多个sql命令的sql语句,我们可以将这些sql脚本放在一个文本文件中,然后通过相关的命令执行这个sql脚本文件,本文就详细的介绍一下,感兴趣的朋友可以了解一下

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

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

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

 

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

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里不能直接创建序列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,使用net stop mysql命令,停止mysql服务

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


 

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


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

方法一:

C:\Users\Administrator>mysql -uroot -p123456 -Djsd170101<D:\day01.sql
//mysql -u账号 -p密码 -D数据库名 < sql文件绝对路径

 

 

方法二:

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


方法三:

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

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

相关文章

  • MySQL中Set与Enum的区别和使用详解

    MySQL中Set与Enum的区别和使用详解

    这篇文章主要介绍了MySQL中Set与Enum的区别和使用详解,数据库中的 set 是一种集合数据类型,用于存储不同的元素,每个元素只能出现一次,Set 的主要作用是方便进行集合运算,如并集、交集等操作,需要的朋友可以参考下
    2024-01-01
  • MySQL数据库表中的约束详解

    MySQL数据库表中的约束详解

    约束是用来限制表中的数据长什么样子的,即什么样的数据可以插入到表中,什么样的数据插入不到表中,下面这篇文章主要给大家介绍了关于如何通过一文理解MySQL数据库的约束与表的设计的相关资料,需要的朋友可以参考下
    2023-03-03
  • MySQL日期及时间字段的查询

    MySQL日期及时间字段的查询

    这篇文章主要介绍了MySQL日期及时间字段的查询,一分享日期及时间字段的规范化查询方法为主展开详细内容,需要的小伙伴可以参考一下
    2022-05-05
  • mysql时间戳转成常用可读时间格式的两种方法

    mysql时间戳转成常用可读时间格式的两种方法

    mysql时间戳转成常用可读时间格式的两种方法,需要的朋友可以参考下。
    2010-09-09
  • 阿里云ECS centos6.8下安装配置MySql5.7的教程

    阿里云ECS centos6.8下安装配置MySql5.7的教程

    阿里云默认yum命令下的MySQL是5.17****,安装mysql5.7之前先卸载以前的版本。下面通过本文给大家介绍阿里云ECS centos6.8下安装配置MySql5.7的教程,需要的的朋友参考下吧
    2017-07-07
  • mysqli多查询特性 实现多条sql语句查询

    mysqli多查询特性 实现多条sql语句查询

    mysqli相对于mysql有很多优势,mysqli连接数据库和mysqli预处理prepare使用,不仅如此,mysqli更是支持多查询特性
    2012-12-12
  • mysql主从复制读写分离的配置方法详解

    mysql主从复制读写分离的配置方法详解

    一般来说mysql都是通过 主从复制(Master-Slave)的方式来同步数据,再通过读写分离(MySQL-Proxy)来提升数据库的并发负载能力 这样的方案来进行部署与实施的。
    2018-04-04
  • mysql的日期和时间函数大全

    mysql的日期和时间函数大全

    mysql的日期和时间函数 这里是一个使用日期函数的例子。下面的查询选择所有 date_col 值在最后 30 天内的记录。
    2008-04-04
  • MySQL中安装样本数据库Sakila过程分享

    MySQL中安装样本数据库Sakila过程分享

    这篇文章主要介绍了MySQL中安装样本数据库Sakila过程分享,Sakila数据库主要用来做一些基本的操作以及压力测试等,需要的朋友可以参考下
    2014-10-10
  • 详解Mysql主从同步配置实战

    详解Mysql主从同步配置实战

    这篇文章主要介绍了详解Mysql主从同步实战,实例分析了Mysql主从同步的原理和实现,非常具有实用价值,需要的朋友可以参考下。
    2017-03-03

最新评论