锦通 发表于 2024-11-1 11:15:49

【MySQL】—— MySQL命令行客户端介绍

目次
(一)mysql客户端简介
(二)mysql客户端选项
2.1 指定选项的方式
2.2 mysql 客户端命令常用选项
2.3 在命令行中使用选项 
(三)选项(设置)文件
3.1 使用方法
3.2 选项文件位置及加载顺序
3.2.1 在Windows系统读取选项文件
3.2.2 在Unix和Linux系统上读取的选项文件 
3.3 选项文件语法
3.4 案例:设置客户端全局编码格式
(四)mysql客户端命令
(五)从.sql文件执行SQL语句 
5.1 使用source命令导入
5.2 使用mysql客户端导入


(一)mysql客户端简介

mysql是⼀个简单的SQLshell,可以输入命令和执行SQL语句,当执行SQL语句时,查询效果以 ASCII 表格式显示
mysql的基本使用非常简单,回顾⼀下连接数据库的⽅式,打开终端并输入以下命令:
#连接MySQL服务器,⻓选项格式
mysql --user=user_name

#短选项格式
mysql -u user_name--password -p

#输⼊密码
Enter password: your_password (二)mysql客户端选项

2.1 指定选项的方式

指定选项的方式


[*]在mysql后面的命令行中列出选项
[*]在mysql后⾯指定设置文件的路径,以便在程序启动时读取设置文件中的选项
[*]使用环境变量中的选项
2.2 mysql 客户端命令常用选项

https://i-blog.csdnimg.cn/direct/795325bfb85a4de9af004ea4f43b0f31.png
    【说明】如果选项的值中包罗空格,那么值须要包罗在双引号中
2.3 在命令行中使用选项 

命令行中指定选项遵循以下规则:


[*]选项应在程序名之后给出
[*]选项以单破折号" "或双破折号"-- "号开头,- 表现短格式,- -表现⻓格式,比方:-?和 --help 都表现MySQL程序显表他的帮助消息
mysql -?
mysql --help

[*]选项名称区分大小写。-v 和-V 都是正当的,但寄义不同,它们分别是--verbose 和 version 选项的相应缩写形式
# 以下两个等价
mysqld --verbose --help
mysqld -v -?

# 以下两个等价
mysql --version
mysql -V

[*]某些选项须要在后面指定⼀个值。比方, 客户端程序指定MySQL服务器主机
mysql -h 127.0.0.1
msyql --host=127.0.0.1

[*]对于带值的长格式选项,通常用 = 符号分隔选项名称和值。对于带值的短选项,选项值可以紧跟在选项之后,也可以用空格隔开,比方:--host= 127.0.0.1 、-h127.0.0.1 和-h 127.0.0.1 是等价的。但是对于暗码选项的短格式,如果要指定暗码,选项与值之间不能有空 格,如下所示:
mysql -ptest# test表⽰密码,但没有指定要访问的数据库
mysql -p test # test 表⽰指定了访问的数据库,但没有指定密码    【说明】在命令行中,第⼀个不带破折号的值被解析为要访问的数据库名,所以--database 选项⼀般可以省略-


[*]在选项名称中,破折号( - )和下划线( _ )在大多数情况下可以交换使用,但前导破折号不能转 为下划线,比方:--skip-grant-tables 和--skip_grant_tables 是等价的。
[*]对于采用数值的选项,该值可以带有后缀 K , M 或 G 以指⽰乘数1024、1024^2或1024^3,例 如,以下命令告诉mysqladmin对服务器执行1024次ping,每次ping之间休眠3秒 
mysqladmin --count=1K --sleep=3 ping -uroot -p

[*]在命令行中包罗空格的选项值必须⽤引号引起来。比方,--execute (or-e )选项与mysql⼀ 起使用时,表现将⼀个或多个SQL语句发送给服务器执行并显示效果
mysql -u root -p -e "SELECT VERSION();SELECT NOW();" https://i-blog.csdnimg.cn/direct/cb4da299089043309d88a8139b5b1e74.png

(三)选项(设置)文件

大多数MySQL程序都可以从选项文件(设置文件)中读取启动选项。可以在选项文件中指定常⽤选项,这样就不⽤在每次运⾏程序时都在命令行中输入它们。大部分选项文件都是纯文本格式,可以使用任何文本编辑器创建。
3.1 使用方法

选项 设置--defaults-file 可以指定要使用的选项⽂件,客户端程序会读取并应用选项文件中的相关.
# Linux
mysql --defaults-file=/etc/mysql/my.cnf -uroot -p

# windows下
mysql "--defaults-file=C:\ProgramData\MySQL\MySQL Server 8.0\my.ini" -uroot -p 3.2 选项文件位置及加载顺序

MySQL按以下表格中的顺序查找并读取选项⽂件。如果文件不存在则须要手动创建。 读取顺序从上到下,后读取的文件中设置的选项优先级越高。
3.2.1 在Windows系统读取选项文件

https://i-blog.csdnimg.cn/direct/ec81d667b3cc4af9b2cd88e65bcbe0b6.png


[*]%WINDIR% 表现Windows目次的位置,可以通过命令查看 
C:\Users\bit>echo %WINDIR%

# 以下是结果
C:\Windows

[*]BASEDIR 表现MySQL的安装目次
C:\Program Files\MySQL\MySQL Server 5.7

[*]%APPDATA% 表现应用程序数据的目次
# 以下是结果
C:\Users\bit\AppData\Roaming

[*]DATADIR 代表MySQL数据目次
C:\ProgramData\MySQL\MySQL Server 5.7    【说明】使用MySQLInstaller安装MySQL乐成后, my.ini 默认在该目次下。
3.2.2 在Unix和Linux系统上读取的选项文件 

https://i-blog.csdnimg.cn/direct/09d13ae8b5c84af0a9cc0d3f2c6517ef.png


[*]~ 表现当前⽤⼾的主目次
[*]MYSQL_HOME 是设置的环境变量路径
[*]DATADIR 代表MySQL数据目次
   mysqld-auto.cnf的优先级最⾼ For the server, one exception applies: The mysqld-auto.cnf option file in the data directory is processed last, so it takes precedence even over command-line options
3.3 选项文件语法

运行MySQL程序时在命令行上指定的任何⻓选项都可以在选项文件中指定,要获取选项列表可以使用如下命令:
# 客⼾端程序
mysql --help

# 服务端程序
mysqld --verbose --help 选项文件中指定选项时,省略两个前导破折号,而且每⼀行表现一个选项 比方:


[*]--quick 和 -host=127.0.0.1 在选项⽂件中应表现成 quick 和 host=127.0.0.1
选项文件中的空行会被忽略。非空行可以采用以下形式:


[*]#comment , ; comment  解释行以 # 或 ; 开,解释可以从⼀行的中间开始
[*][ group ] 设置选项的程序或组的名称,不区分大小写。如果选项组名称与程序名称雷同,则组中的选项专门应用于该程序,比方, 和 组分别适用于mysqld服务端程序和 mysql客户端程序
[*]op t_name 相当于命令行上的选项名
[*]op t_name = value 选项名对应的值,可以使⽤转义序列 \b , \t , \n , \r , \\ 和 \s 来表现退格符、制表符、换行符、回车符、反斜杠和空格字符
   1. 选项名称和值中的前导和尾随空格会自动删除
2. 在windows系统中设置路径应该使用转义字符
 
 basedir= "C:\\Program Files\\MySQL\\MySQL Server 5.7"

# 或

basedir= "C:\\Program Files\\MySQL\\MySQL Server 5.7"  MySQL发⾏版中所有客户端程序都会读取并应用这个组下的选项(除了mysqld), 在这个组下可以指定适用于所有客户端程序的通用选项,比方设置用户名和暗码(但要确保只有自己才可以访问这个文件以防止暗码泄漏)
https://i-blog.csdnimg.cn/direct/57e80c63fa4e490f80778a9959b2caa4.png
可以通过 [ 客户端程序名 ] 的形式为不同的客户端程序指定选项,比方 mysql程序时会读取并应用该组下的设置,如果选项名与 ,当运行  重复, 中的选项将会被覆盖 
https://i-blog.csdnimg.cn/direct/98dc4823057b4440a2b285f1d73251fd.png
为特定MySQL版本设置选项可以使用
在选项文件中使用 、 的组名 !include 指令来包罗其他选项文件,比方: /home/mydir/myopt.cnf
在选项文件使用 ! include !includedir 指令来搜索指定目次中的其他选项文件,例 如: ! include /home/mydir ,但不保证目次中选项文件的读取顺序 
    【说明】
1. !includedir 在Unix和Linux操纵系统中会搜索指定目次下任何以 在Windows中,会搜索指定目次下任何以 .cnf 为后缀的文件. .ini 或 .cnf 为后缀的⽂件
2. 只会读取包罗⽂件中当前客户端的组设置,比方当前运行的是mysql程序,那么只会读取 组中的选项设置 
在Windows中请确保在设置文件的最后⼀行加⼀个换行符,否则该行将被忽略
3.4 案例:设置客户端全局编码格式

在Linux下编辑全局设置文件默认位置 /etc/mysql/my.cnf 。在已有内容下方输入相应的设置,我们要为客户端设置全局的编码格式为utf8mb4,那么在 节点下指定相应的选项即可
   # 所有客⼾端程序者会读取这个节点下的配置信息   
                  
default-character-set=utf8mb4   #指定编码格式为utf8mb4

(四)mysql客户端命令

使用mysql客户端程序连接到数据库服务器之后,可以发送SQL语句到服务器执⾏,并以";"(分 号)、\g 或\G 结束
    【说明】
1. ; 与 \g 结束表现以表格形式展示效果
2. \G 结束表现以行形式展示效果
3. 如果当前已经输入了⼀部分SQL语句想重新输入可以输入 Control+C 中断当前输入
在当前模式下,mysql还有⼀组自己的命令,可以输入  help or \h 查看命令列表
https://i-blog.csdnimg.cn/direct/d122d2b39a024890bd010c1ea5304d6c.png
使用 help contents命令可以查看关于MySQL数据库使用的具体帮助,包括用户管理、SQL语法、 数据范例、组件等相关内容列表
https://i-blog.csdnimg.cn/direct/72dc6dfae28e4c03b740f3a93ae4f38a.png
通过help contents中的具体条目查看介绍,比方:help Data Types 
https://i-blog.csdnimg.cn/direct/bac7288c11ba451098fd4b929e317f4e.png
(五)从.sql文件执行SQL语句 

5.1 使用source命令导入

有时候我们须要从.sql⽂件执行⼀些SQL语句,比如要把⼀个数据库从⼀台服务器A复制到另⼀台服务 器B上,那么可以先从服务器A导出数据到.sql文件,然后在服务器B执行这个.sql⽂件,在上述, 用help命令查看命令列表,可以看到有⼀个source命令如下所示:
https://i-blog.csdnimg.cn/direct/c821422ce623458385800cede7a52fb7.png
   下⾯我们演示⼀下source命令的使用方法


[*]1. 准备要执行的.sql文件,名为 test_db.sql,内容如下: 
https://i-blog.csdnimg.cn/direct/0b991ac37bc540c8abad7424d5f0fa95.png
classes 表: 
https://i-blog.csdnimg.cn/direct/c91301f3b6f24c79b1427196f91fecd8.png
https://i-blog.csdnimg.cn/direct/6021bab056434b199e9d07cd183c3509.png
 course 表:
https://i-blog.csdnimg.cn/direct/a5ae182cdadc43b8a44550943fe2a49d.png
 
https://i-blog.csdnimg.cn/direct/b6de5fe501e743eda4c8d41f5b0c41ad.png


[*] 2. 确定.sql文件的绝对路径:/home/zp/database/test_db.sql
ll /home/zp/database/test_db.sql

[*] 3. 连接数据库查看已有数据库
show databases;

[*]4. 使用source命令执行.sql文件的SQL语句
source /home/zp/database/test_db.sql

[*]5. 查看数据库并查询数据,验证导入是否乐成
https://i-blog.csdnimg.cn/direct/8ac066d79ba74b4992b093e3bb6eecd8.png
5.2 使用mysql客户端导入



[*]直接使用mysql客户端程序导入.sql⽂件并执行相应的SQL语句,可以使用以下命令
mysql db_name < text_file# 在指定的数据库下执⾏ SQL, 前提是数据库必须提前建⽴好

mysql < text_file # 不指定数据库.sql中必须有USE ,来指定要操作的数据库


[*]登录数据库并验证是否导入乐成 可以根据实际须要选择导入.sql的方式


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 【MySQL】—— MySQL命令行客户端介绍