从 01 开始 从 01 开始
首页
  • 📚 计算机基础

    • 计算机简史
    • 数字电路
    • 计算机组成原理
    • 操作系统
    • Linux
    • 计算机网络
    • 数据库
    • 编程工具
    • 装机
  • 🎨 前端

    • Node
  • JavaSE
  • Java 高级
  • JavaEE

    • 构建、依赖管理
    • Ant
    • Maven
    • 日志框架
    • Junit
    • JDBC
    • XML-JSON
  • JavaWeb

    • 服务器软件
    • 环境管理和配置管理-科普篇
    • Servlet
  • Spring

    • Spring基础
  • 主流框架

    • Redis
    • Mybatis
    • Lucene
    • Elasticsearch
    • RabbitMQ
    • MyCat
    • Lombok
  • SpringMVC

    • SpringMVC 基础
  • SpringBoot

    • SpringBoot 基础
  • Windows 使用技巧
  • 手机相关技巧
  • 最全面的输入法教程
  • 最全面的浏览器教程
  • Office
  • 图片类工具
  • 效率类工具
  • 最全面的 RSS 教程
  • 码字工具
  • 各大平台
  • 校招
  • 五险一金
  • 职场规划
  • 关于离职
  • 杂谈
  • 自媒体
  • 📖 读书

    • 读书工具
    • 走进科学
  • 🌍 英语

    • 从零开始学英语
    • 英语兔的相关视频
    • Larry 想做技术大佬的相关视频
  • 🏛️ 政治

    • 反腐
    • GFW
    • 404 内容
    • 审查与自我审查
    • 互联网
    • 战争
    • 读书笔记
  • 💰 经济

    • 关于税
    • 理财
  • 💪 健身

    • 睡眠
    • 皮肤
    • 口腔健康
    • 学会呼吸
    • 健身日志
  • 🏠 其他

    • 驾驶技能
    • 租房与买房
    • 厨艺
  • 电影

    • 电影推荐
  • 电视剧
  • 漫画

    • 漫画软件
    • 漫画推荐
  • 游戏

    • Steam
    • 三国杀
    • 求生之路
  • 小说
  • 关于本站
  • 关于博主
  • 打赏
  • 网站动态
  • 友人帐
  • 从零开始搭建博客
  • 搭建邮件服务器
  • 本站分享
  • 🌈 生活

    • 2022
    • 2023
    • 2024
    • 2025
  • 📇 文章索引

    • 文章分类
    • 文章归档

晓林

程序猿,自由职业者,博主,英语爱好者,健身达人
首页
  • 📚 计算机基础

    • 计算机简史
    • 数字电路
    • 计算机组成原理
    • 操作系统
    • Linux
    • 计算机网络
    • 数据库
    • 编程工具
    • 装机
  • 🎨 前端

    • Node
  • JavaSE
  • Java 高级
  • JavaEE

    • 构建、依赖管理
    • Ant
    • Maven
    • 日志框架
    • Junit
    • JDBC
    • XML-JSON
  • JavaWeb

    • 服务器软件
    • 环境管理和配置管理-科普篇
    • Servlet
  • Spring

    • Spring基础
  • 主流框架

    • Redis
    • Mybatis
    • Lucene
    • Elasticsearch
    • RabbitMQ
    • MyCat
    • Lombok
  • SpringMVC

    • SpringMVC 基础
  • SpringBoot

    • SpringBoot 基础
  • Windows 使用技巧
  • 手机相关技巧
  • 最全面的输入法教程
  • 最全面的浏览器教程
  • Office
  • 图片类工具
  • 效率类工具
  • 最全面的 RSS 教程
  • 码字工具
  • 各大平台
  • 校招
  • 五险一金
  • 职场规划
  • 关于离职
  • 杂谈
  • 自媒体
  • 📖 读书

    • 读书工具
    • 走进科学
  • 🌍 英语

    • 从零开始学英语
    • 英语兔的相关视频
    • Larry 想做技术大佬的相关视频
  • 🏛️ 政治

    • 反腐
    • GFW
    • 404 内容
    • 审查与自我审查
    • 互联网
    • 战争
    • 读书笔记
  • 💰 经济

    • 关于税
    • 理财
  • 💪 健身

    • 睡眠
    • 皮肤
    • 口腔健康
    • 学会呼吸
    • 健身日志
  • 🏠 其他

    • 驾驶技能
    • 租房与买房
    • 厨艺
  • 电影

    • 电影推荐
  • 电视剧
  • 漫画

    • 漫画软件
    • 漫画推荐
  • 游戏

    • Steam
    • 三国杀
    • 求生之路
  • 小说
  • 关于本站
  • 关于博主
  • 打赏
  • 网站动态
  • 友人帐
  • 从零开始搭建博客
  • 搭建邮件服务器
  • 本站分享
  • 🌈 生活

    • 2022
    • 2023
    • 2024
    • 2025
  • 📇 文章索引

    • 文章分类
    • 文章归档
  • 计算机简史

  • 数字电路

  • 计算机组成原理

  • 操作系统

  • Linux

  • 计算机网络

  • 数据库

    • 教程概述
    • 数据的存储
    • 数据库的安装
    • 数据库的启停与连接
    • 数据库的管理
    • SQL 概述
    • 表的管理
    • SELECT 基础
    • 运算符
    • 聚合查询
    • 数据的排序
    • 数据的插入
    • 数据的删除
    • 数据的更新
    • 事务
    • 视图
    • 子查询
    • 函数
    • 谓词
    • CASE 表达式
    • 集合运算
    • 联结查询-JOIN
    • SQL 入门小结
    • 更多数据库
    • MySQL 的数据类型
    • 命令行的一些用法
      • 清屏
      • 使用列的方式展示
      • SQL 语句中的分号
      • 预读
      • 执行外部文件
      • 查看 warning
      • 记录执行记录
    • 用户与权限管理
    • MySQL 的权限管理
    • mysqldump
    • mysqladmin
    • Liquibase
    • 表注释与字段注释
    • 编码类型
  • 编程工具

  • 装机

  • 计算机基础
  • 数据库
2023-12-04
目录

命令行的一些用法

# 270.命令行的一些用法

介绍一下日常使用中会用到的命令。

‍ ‍

# 清屏

如果使用命令行操作数据库,随着时间的推移,屏幕上会出现很多结果。此时可以用清屏指令使得屏幕变干净:

mysql> system cls
1

‍ 效果:干干净净

​​

# 使用列的方式展示

如果一行的数据太多,在命令行会显示换行的情况,看起来很不直观。此时可以使用\G 参数,表示按列查看:

mysql> select * from Product \G
*************************** 1. row ***************************
    product_id: 0001
  product_name: T恤衫
  product_type: 衣服
    sale_price: 1000
purchase_price: 500
   regist_date: 2009-09-20
*************************** 2. row ***************************
    product_id: 0002
  product_name: 打孔器
  product_type: 办公用品
    sale_price: 500
purchase_price: 320
   regist_date: 2009-09-11
............................
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

说明:

  • 使用 \G 后,结尾不用加分号(;)也行
  • 由于数据太多,这里只将前 2 行的数据贴出来 ‍

# SQL 语句中的分号

在写 SQL 语句时,如果没有出现分号,那么即使回车也不会执行,因为 MySQL 的控制台认定只有出现分号的时候,才是一条完整的语句,所以在使用 MySQL 时一条语句可以分成多行输入。

如果要在命令行里执行多行 SQL,这样就更更美观一点

mysql> select *
    -> from Product
    -> where product_type = '衣服'
    -> ;
1
2
3
4

‍

# 预读

-A:使用该参数时,不预读数据库信息。

默认情况下,切换数据库后就会预读数据库中的表信息。当数据库很大或者表数量很多时,切换数据库会比较慢。

参考如下提示:

mysql> use LearnSQL
Reading table information for completion of table and column names. You can turn off this feature to get a quicker startup with -A

Database changed
1
2
3
4

‍ 用法:在登录时加上该参数

mysql -uroot -p -A
1

‍

# 执行外部文件

我们可以将一个 SQL 保存到文本文件中(注意文件后缀改为.sql)。例如,新建 D:\test.sql,内容如下:

use shop;
select * from Product;
1
2

‍ 如果想要在命令行里执行该文件内的 SQL,有两种方法:

  • source 命令
  • mysql 命令 ‍ 方法 1:在 MySQL 里,执行 source 命令:
-- 语法:
source sql脚本文件路径全名

-- 例如:
mysql> source D:\test.sql
Database changed
+------------+--------------+--------------+------------+----------------+-------------+
| product_id | product_name | product_type | sale_price | purchase_price | regist_date |
+------------+--------------+--------------+------------+----------------+-------------+
| 0001       | T恤衫        | 衣服         |       1000 |            500 | 2009-09-20  |
| 0002       | 打孔器       | 办公用品     |        500 |            320 | 2009-09-11  |
| 0003       | 运动T恤      | 衣服         |       4000 |           2800 | NULL        |
| 0004       | 菜刀         | 厨房用具     |       3000 |           2800 | 2009-09-20  |
| 0005       | 高压锅       | 厨房用具     |       6800 |           5000 | 2009-01-15  |
| 0006       | 叉子         | 厨房用具     |        500 |           NULL | 2009-09-20  |
| 0007       | 擦菜板       | 厨房用具     |        880 |            790 | 2008-04-28  |
| 0008       | 圆珠笔       | 办公用品     |        100 |           NULL | 2009-11-11  |
+------------+--------------+--------------+------------+----------------+-------------+
8 rows in set (0.00 sec)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

方法 2:使用 mysql 命令。平时我们都是用 mysql -uroot 的方式来登录数据库,其实也传递一个文件给该命令,让其执行文件内的 SQL:

-- 语法:
mysql -u <username> -p <password> -h <host> -P <port> <database> < <sql_file>
1
2

参数说明:

  • ​<username>​: 数据库用户名
  • ​<password>​: 数据库密码
  • ​<host>​: 数据库主机地址
  • ​<port>​: 数据库端口号
  • ​<database>​: 数据库名称
  • ​<sql_file>​: SQL 文件的路径 ‍ 例如:
-- :
mysql -uroot -p shop < D:\test.sql
1
2

‍ 注意:必须指定数据库,如果在命令行里有指定数据库,则文件内可以省略;反之如果文件内指定了,则命令行里可以省略。

除了命令行,一般 MySQL 的图形化工具也能导入和执行 SQL 文件。

# 查看 warning

在执行 SQL 的过程中,有时候会有一些警告,此时可以用 show warnings; ​来查看警告信息

比如,创建表时,给整数类型加个显示宽度的属性(后续我们讲数据类型时会介绍该属性):

CREATE TABLE  temp (
  id int(4)
);
1
2
3

‍ 从 MySQL 8.0.17 开始,整数数据类型不推荐使用显示宽度属性,后续的版本可能会删除该属性,因此我们创建该表的时候,会有个警告:

-- 结果:
Query OK, 0 rows affected, 1 warning (0.01 sec)


-- 如果是正常的情况,是没有警告的,例如:
Query OK, 0 rows affected (0.00 sec)  
1
2
3
4
5
6

‍ 此时我们就可以用 show warnings; ​来查看警告了:

mysql> show warnings;
+---------+------+-----------------------------------------------------------------------+
| Level   | Code | Message                                                                      |
+---------+------+-----------------------------------------------------------------------+
| Warning | 1681 | Integer display width is deprecated and will be removed in a future release. |
+---------+------+-----------------------------------------------------------------------+
1 row in set (0.00 sec)
1
2
3
4
5
6
7

‍ 如果嫌这样看 warnings 有点麻烦,可以在连接数据库的选项中加上--show-warnings,直接将显示 warnings。效果:

mysql -uroot -p --show-warnings

mysql> use shop;

mysql> CREATE TABLE  temp (
    ->   id int(4)
    -> );
Query OK, 0 rows affected, 1 warning (0.02 sec)

Warning (Code 1681): Integer display width is deprecated and will be removed in a future release.
1
2
3
4
5
6
7
8
9
10

注意:

  1. 如果在执行完一个 SQL 后,有 warning;但是后续又执行了第二条 SQL,那么第一条 SQL 的 warning 信息就看不到了
  2. 如果是使用可视化工具,一般都会直接显示警告信息 ‍

# 记录执行记录

有时候我们会在 MySQL 命令行里执行很多很多的内容,但当内容多了以后,不方便查看;此外如果不小心关闭了终端,那么之前的执行记录都会不见。

在 mysql 内执行 tee 日志文件名​,该命令就会将执行记录,保存到该文件内。 ‍ 使用 tee 日志文件名的效果:

mysql> tee d:\import.log
1

‍ 打开 D 盘的日志文件 import.log,内容如下:


mysql> tee import.log
Logging to file 'import.log'
mysql>
mysql> use ssm;
Database changed
mysql> show tables;
+---------------+
| Tables_in_ssm |
+---------------+
| account       |
| temp          |
+---------------+
2 rows in set (0.01 sec)
1
2
3
4
5
6
7
8
9
10
11
12
13
14

‍ (未完待续)

上次更新: 2025/5/5 17:15:09
MySQL 的数据类型
用户与权限管理

← MySQL 的数据类型 用户与权限管理→

最近更新
01
语雀文档一键下载至本地教程
07-04
02
要成功,就不要低估环境对你的影响
07-03
03
血泪教训:电子设备要定期开机
07-02
更多文章>
Theme by Vdoing | Copyright © 2022-2025 | 粤 ICP 备 2022067627 号 -1 | 粤公网安备 44011302003646 号 | 点击查看十年之约
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式