2 - 表结构 | MySQL键值
表结构 | MySQL键值
- 表管理
- 1. 库的操作
- 2. 表的操作
- 表的创建与删除
- 表的修改
- 复制表
- 3. 管理表记录
- 数据类型
- 数值类型
- 字符类型(汉字或者英文字母)
- 日期时间类型 表头存储与日期时间格式的数据
- 枚举类型
- 数据批量处理
表管理
客户端把数据存储到数据库服务器上的过程
- 第一步连接数据库
- 第二步创建存储数据的库(存放表的目录)
- 第三步创建存储数据的表(表就是存储数据的文件)
- 第四步插入表记录(向文件里添加行)
- 第五步断开连接
1. 库的操作
建库的基本命令 create database 库名(必须唯一性!!!)
[root@host50 ~]# mysql -uroot -pxxxx //数据库管理员登陆
mysql> select user(); # 查看登陆的用户
+----------------+
| user() |
+----------------+
| root@localhost | 用户@客户端地址 (在本机管理员登录)
+----------------+
1 row in set (0.00 sec)mysql> show databases; # 查看已有的库
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
| tarena |
+--------------------+
5 rows in set (0.00 sec)mysql> select database(); # 查看当前所在的库
+------------+
| database() |
+------------+
| NULL | 表示没有在任何一个库,此时所在的位置是/var/lib/mysql 目录
+------------+
1 row in set (0.00 sec)mysql> create database db1 # 创建新库
Query OK, 1 row affected (0.00 sec)mysql> show databases; 此时查看已有库
+--------------------+
| Database |
+--------------------+
| information_schema |
| db1 | 刚创建的db1库 , 在数据库目录/var/lib/myql 下会有对应名称的db1目录
| mysql |
| performance_schema |
| sys |
| tarena |
+--------------------+
6 rows in set (0.00 sec)mysql> system ls -ld /var/lib/mysql/db1; # 使用system 命令 在登录状态下执行系统命令
drwxr-x--- 2 mysql mysql 20 9月 7 13:52 /var/lib/mysql/db1mysql> create database if not exists DB1; 加if not exists语句避免重名报错
Query OK, 1 row affected, 1 warning (0.01 sec)// 删除库 如果库里有表会一并被删除
mysql> drop database db1 ; 删除没有的库,会报错
mysql> drop database if exists db1; 加if exists 语句 避免报错
2. 表的操作
建表命令格式
create table 库名.表名(
表头名 数据结构 [约束条件],
表头名 数据结构 [约束条件]
);
表的创建与删除
使用建表范式衡量表创建的是否合理
- 1NF 表头下的数据不能再拆分
- 2NF 一张表里只存储一种数据信息,不能用一张存储多种数据信息
- 3NF 表中表头的数据 不能依赖其他表头的数据
mysql> create table DB1.t1(姓名 char(10),班级 char(7)); # 在DB1库里创建t1表mysql> desc DB1.t1; 查看表头信息
+--------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+----------+------+-----+---------+-------+
| 姓名 | char(10) | YES | | NULL | |
| 班级 | char(7) | YES | | NULL | |
+--------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)mysql> drop table DB1.t1; 删除创建的表
Query OK, 0 rows affected (0.11 sec)为了便于操作通常使用英文定义表头名和表名
mysql> create table DB1.t1 ( name char(15) , class char(10));
Query OK, 0 rows affected (0.25 sec)
mysql> desc DB1.t1; 查看表头
+-------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| name | char(15) | YES | | NULL | |
| class | char(10) | YES | | NULL | |
+-------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)
表的修改
发现表建的不合理 可以修改表
- 添加新表头 add
- 删除表头 drop
- 修改表头存储数据的数据类型 modify
- 修改表头名 change
- 修改表名 rename
alter table 库名.表名 操作命令
mysql> alter table DB1.t1 add school char(20) ; 添加1个新字段school
mysql> desc DB1.t1; 默认新添加的字段追加在已有列的末尾
+--------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+----------+------+-----+---------+-------+
| name | char(15) | YES | | NULL | |
| class | char(10) | YES | | NULL | |
| school | char(20) | YES | | NULL | |
+--------+----------+------+-----+---------+-------+
3 rows in set (0.00 sec)一起添加2个字段 分别是 mail 和 address
mysql> alter table DB1.t1 add mail char(50) , add address char(80) ;
Query OK, 0 rows affected (0.37 sec)
Records: 0 Duplicates: 0 Warnings: 0mysql> desc DB1.t1; 查看新添加的表头,都在追加在末尾
+---------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+----------+------+-----+---------+-------+
| name | char(15) | YES | | NULL | |
| class | char(10) | YES | | NULL | |
| school | char(20) | YES | | NULL | |
| mail | char(50) | YES | | NULL | |
| address | char(80) | YES | | NULL | |
+---------+----------+------+-----+---------+-------+
5 rows in set (0.00 sec)添加新表头number 在第1列的位置
mysql> alter table DB1.t1 add number int first ;
Query OK, 0 rows affected (0.32 sec)
Records: 0 Duplicates: 0 Warnings: 0
添加新表头在city 放在name的后边
mysql> alter table DB1.t1 add city char(10) after name;
Query OK, 0 rows affected (0.42 sec)
Records: 0 Duplicates: 0 Warnings: 0mysql> desc DB1.t1;
+---------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+----------+------+-----+---------+-------+
| number | int(11) | YES | | NULL | |
| name | char(15) | YES | | NULL | |
| city | char(10) | YES | | NULL | |
| class | char(10) | YES | | NULL | |
| school | char(20) | YES | | NULL | |
| mail | char(50) | YES | | NULL | |
| address | char(80) | YES | | NULL | |
+---------+----------+------+-----+---------+-------+
7 rows in set (0.00 sec)mysql> alter table DB1.t1 drop city; 一次删除一个表头
Query OK, 0 rows affected (0.31 sec)
Records: 0 Duplicates: 0 Warnings: 0mysql> alter table DB1.t1 drop class , drop school; 一起删除多个表头
Query OK, 0 rows affected (0.32 sec)
Records: 0 Duplicates: 0 Warnings: 0mysql> desc DB1.t1; 查看表头
+---------+----------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+----------+------+-----+---------+-------+
| number | int(11) | YES | | NULL | |
| name | char(15) | YES | | NULL | |
| mail | char(50) | YES | | NULL | |
| address | char(80) | YES | | NULL | |
+---------+----------+------+-----+---------+-------+
4 rows in set (0.00 sec)// 修改表头信息
mysql> alter table DB1.t1 modify number tinyint after name; 修改类型和位置
mysql> desc DB1.t1; 查看修改,把类型修改为tinyint 并移动name表头的后边
+---------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+------------+------+-----+---------+-------+
| name | char(15) | YES | | NULL | |
| number | tinyint(4) | YES | | NULL | |
| mail | char(50) | YES | | NULL | |
| address | char(80) | YES | | NULL | |
+---------+------------+------+-----+---------+-------+
4 rows in set (0.00 sec)mysql> alter table DB1.t1 change address homedir char(80); 只修改表头名,类型原样抄下来
Query OK, 0 rows affected (0.05 sec)
Records: 0 Duplicates: 0 Warnings: 0mysql> desc DB1.t1;查看修改,address 修改为了 homedir
+---------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+------------+------+-----+---------+-------+
| name | char(15) | YES | | NULL | |
| number | tinyint(4) | YES | | NULL | |
| mail | char(50) | YES | | NULL | |
| homedir | char(80) | YES | | NULL | |
+---------+------------+------+-----+---------+-------+
4 rows in set (0.00 sec)mysql> alter table DB1.t1 change email vachar(60); 表头名和类型一起修改
Query OK, 0 rows affected (0.44 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> desc DB1.t1;查看修改表头名类型都变了
+---------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| name | char(15) | YES | | NULL | |
| number | tinyint(4) | YES | | NULL | |
| email | varchar(60) | YES | | NULL | |
| homedir | char(80) | YES | | NULL | |
+---------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)mysql> alter table DB1.t1 rename stuinfo; 修改表名为 stuinfo
mysql> show tables; 查看表名 已经改变
+---------------+
| Tables_in_DB1 |
+---------------+
| stuinfo |
+---------------+
复制表
- 仅复制表结构
mysql> create table DB1.t2 select * from tarena.user where 1=2 ; 复制表结构及数据
- 复制表结构和数据
mysql> create table DB1.t3 select * from tarena.user
- 仅复制表结构
create table 库.表名 like 库.表名
# 原来的key也会复制给新表 复制不了数据
3. 管理表记录
对表中存储的行做管理 操作 包括
- 查询 : 查看表中的行 select
- 插入 : 向表中添新的行 insert into
添加1行给所有表头赋值
mysql> insert into DB1.stuinfo values ("yaya",1,"yaya@tedu.cn","beijing");
Query OK, 1 row affected (0.03 sec)添加1行 ,给指定的表头赋值,
mysql> insert into DB1.stuinfo (name,homedir)values("nb","nb@tedu.cn");
Query OK, 1 row affected (0.04 sec)没有赋值的表头number和email 没有数据 ,值是 null (空)
mysql> select * from DB1.stuinfo;
+------+--------+--------------+-------------+
| name | number | email | homedir |
+------+--------+--------------+-------------+
| yaya | 1 | yaya@tedu.cn | beijing |
| plj | 8 | plj@163.com | shanghai |
| jing | 9 | jing@163.com | beijing |
| nb | NULL | NULL | nb@tedu.cn |
| nb2 | NULL | NULL | nb2@tedu.cn |
| nb3 | NULL | NULL | nb3@tedu.cn |
+------+--------+--------------+-------------+
6 rows in set (0.00 sec)使用set语句插入记录
mysql> insert into DB1.stuinfo set name="plj" , number=10;
- 更新 : 修改行中列的数据 update
mysql> update DB1.stuniof set email="stu@163.com" where email is null;不加条件批量修改
mysql> update DB1.stuinfo set homedir="beijing";
- 删除 : 删除表中的行 delete
// 只删除与条件符合的行
delete from DB1.stuinfo where name regexp '^nb';//删除表里的所有行
delete from 库.表也可用truncate table 库.表;
自增长列 truncate后从1开始 delete继续变好
truncate不能回滚 delete可以
效率略高于delete
数据类型
包括 数值类型、字符类型、日期时间类型、枚举类型
数值类型
- 整数类型
- 浮点类型
字符类型(汉字或者英文字母)
- char 定长 (固定长度) 1-255字节
- varchar 变长 (长度不固定) 1-65535
默认不允许给表头存储中文 要存储中文 要指定使用的字符集
mysql> show create table db1.t3 # 查看字符集
ENGINE=InnoDB # 定义存储引擎
DEFAULT CHARSET =latin1 # 定义字符集# 建表的时候指定使用的字符集
create table db1.t4(姓名 char(3),地址 varchar(10)) DEFAULT CHARSET utf8;
日期时间类型 表头存储与日期时间格式的数据
mysql> create table db1.t6(
姓名 char(4),
生日 date,
上课时间 time,
家庭聚会 datetime,
聚会地点 varchar(10)
) DEFAULT CHARSET utf8;mysql> alter table db1.t6 add 出生年份 year after 姓名;
datetime 与 datestamp的区别
- 第一个存储范围不一样(datetime存储范围大 timestamp范围小)
- 存储数据的方式不一样 当未给timestamp字段值 自动以当前系统时间赋值,而datetime值为NULL
枚举类型
给表头赋值时,值必须在类型规定的范围内选择
- 单选 enum (值1,值2,值3…)
- 多选 set (值1,值2,值3…)
create table db1.t8(姓名 char(10) , 性别 enum("男","女","保密") ,
爱好 set("帅哥","金钱"。)
);
数据批量处理
一次性向表里存储很多数据 或 一次性把表里的数据都取出来
注意:数据导入或导出 存放数据的文件必须在mysql服务要求的目录下 叫检索目录
要知道数据库默认的检索目录
会修改数据库默认的检索目录
查看默认的检索目录mysql > show variables like "secure_file_priv"
修改默认的检索目录vim /etc/my.cnf [mysql] secure_file_priv=/myload # 手动添加 mkdir /myload chown mysql /myload/ # 给权限
- 数据导入(文件的内容一定要有规律)
- 将/etc/passwd文件导入db1库的t3表里
- 文件导入格式
- mysql> load data infile “/检索目录/文件名” into table 库名.表名 fileds terminated by "文件中列的间隔符号 " lines terminated by “/n”
- 数据导入的操作步骤:
-
- 创建存储数据的库
-
- 根据导入文件的内容 建表
-
- 把系统文件拷贝到检索目录
-
- 数据库管理执行导入数据的命令
-
- 查看数据
-
- 数据导出 导出的不包括表头名 只有表里的行 导出的文件名 不需要事先创建 且具有唯一性
-
- select 字段名列表 from 库.表 where 条件 into outfile “/检索目录名/文件名”
-
- select 字段名列表 from 库.表 where 条件 into outfile “/检索目录名/文件名” fields terminated by “符号”
- fields terminated by 指定导出的列在文件中的间隔符号。不止定 默认时一个tab的宽度
-
- select 字段名列表 from 库.表 where 条件 into outfile “/检索目录名/文件名” fields terminated by “符号” lines terminated by “符号”
- lines terminated by 指定导出的行在文件中的间隔符号。不止定 默认一条记录就是一行
-
相关文章:

2 - 表结构 | MySQL键值
表结构 | MySQL键值 表管理1. 库的操作2. 表的操作表的创建与删除表的修改复制表 3. 管理表记录 数据类型数值类型字符类型(汉字或者英文字母)日期时间类型 表头存储与日期时间格式的数据枚举类型 数据批量处理 表管理 客户端把数据存储到数据库服务器上…...

Redis(Linux版本7.2.3)
1、停止Redis服务器 [roottssvr1-c1 sysconfig]# ps -ef | grep redis root 322 1 0 10月30 ? 02:58:53 ./bin/redis-server 0.0.0.0:6379 root 32664 12498 0 14:45 pts/0 00:00:00 grep --colorauto redis [roottssvr1-c1 sysconfig]# [roottssvr…...
八股文打卡day18——操作系统(1)
面试题:进程和线程的区别? 我的回答: 1.概念上。进程是系统进行资源分配和调度的基本单位。线程是系统进行运算调度的最小单位。线程是进程的子任务,一个进程至少包含一个线程,一个进程可以运行多个线程,…...

设计模式—行为型模式之模板方法模式
设计模式—行为型模式之模板方法模式 在模板模式(Template Pattern)中,一个抽象类公开定义了执行它的方法的方式模板。它的子类可以按需要重写方法实现,但调用将以抽象类中定义的方式进行。 模板方法(Template Metho…...

机器学习的分类与经典算法
机器学习算法按照学习方式分类,可以分为有监督学习(Supervised Learning)、无监督学习(Unsupervised Learning)、半监督学习(Semi-supervised Learning)、强化学习(Reinforcement Le…...

2.3物理层下面的传输媒体
目录 2.3物理层下面的传输媒体2.3.1导引型传输媒体1.双绞线2.同轴电缆3.光纤 2.3.2非导引型传输媒体无线电微波通信 2.3物理层下面的传输媒体 传输媒体是数据传输系统中在发送器和接收器之间的物理通路 两大类: 导引型传输媒体:电磁波被导引沿着固体媒体…...
笙默考试管理系统-MyExamTest----codemirror(57)
笙默考试管理系统-MyExamTest----codemirror(57) 目录 一、 笙默考试管理系统-MyExamTest----codemirror 二、 笙默考试管理系统-MyExamTest----codemirror 三、 笙默考试管理系统-MyExamTest----codemirror 四、 笙默考试管理系统-MyExamTest---…...

Qt高质量的开源项目合集
文章目录 1.Qt官网下载/文档2.第三方开源 1.Qt官网下载/文档 Qt Downloads Qt 清华大学开源软件镜像站 Qt 官方博客 2.第三方开源 记录了平常项目开发中用到的第三方库,以及一些值得参考的项目! Qt AV 基于Qt和FFmpeg的跨平台高性能音视频播放框…...
HarmonyOS ARKUI深度解析:图像组件及权限配置实战指南
文章目录 深入学习RKUI中的图片组件及权限配置图片组件简介图片源的三种格式Image : 图片显示组件图片组件属性及样式控制图片权限配置文章总结问题总结深入学习RKUI中的图片组件及权限配置 在本文中,我们将深入学习ArkUI(HarmonyOS UI框架)中的图片组件及其相关属性,同时…...

萨姆·奥尔特曼的预言
Sam Altman(萨姆奥尔特曼)是 OpenAI 的首席执行官,这家初创公司开发了众所周知的 ChatGPT。2023年11月,他突然被董事会解雇,并短暂调往微软。在 OpenAI 的每个人都威胁要辞职后,他又回来了。 新的商业模式…...

iPhone 13 Pro 更换『移植电芯』和『超容电池』体验
文章目录 考虑换电池Ⅰ 方案一Ⅱ 方案二 总结危险 Note系列地址 简 述: 首发买的iPhone 13P (2021.09),随性使用一年出头,容量就暴跌 85%,对比朋友一起买的同款,还是95%。这已经基本得一天两充 >_<&a…...
JavaScript 常用事件演示
Hi i,m JinXiang ⭐ 前言 ⭐ 本篇文章主要介绍在在JavaScript 常用事件演示以及部分理论知识 🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁 🍉博主收将持续更新学习记录获,友友们有任何问题可以在评论区…...

gzip引入后node_modules中.cache compression-webpack-plugin占用内存过多
1.Gzip Gzip(GNU zip)是一种常见的文件压缩格式和压缩算法,通常用于在 Web 服务器上对静态资源文件进行压缩,以减小文件大小并加快文件传输速度。在前端开发中,经常会使用 Gzip 压缩来优化网站的性能。 Gzip 压缩通过…...

Vue:使用IDEA开发Vue的相关配置
一、IDEA无法识别.vue文件 1、IDEA 添加Vue插件 2、添加Vue配置 File | Settings | Editor | File Types 找到 HTML 文件 在下面点号 输入*.vue 二、IDEA无法创建.vue文件 1、问题 在开发过程中,发现创建文件的界面,没有vue模板 2、相关配置 Fi…...

黑马程序员SSM框架-SpringBoot
视频连接:SpringBoot-01-SpringBoot工程入门案例开发步骤_哔哩哔哩_bilibili SpringBoot简介 入门程序 也可以基于官网创建项目。 SpringBoot项目快速启动 下面的插件将项目运行所需的依赖jar包全部加入到了最终运行的jar包中,并将入口程序指定。 Spri…...
Javascript细节、经验锦集
【版权声明】未经博主同意,谢绝转载!(请尊重原创,博主保留追究权) https://blog.csdn.net/m0_69908381/article/details/135311084 出自【进步*于辰的博客】 纯文字阐述,内容比较干。并且,由于考…...

git的使用基础教程
最近项目在搞自动化测试,需要将各种测试脚本集成到自动化框架里边,这个就需要用到版本管理系统了,下面简单价绍一下git的使用。 首先从官网下载并安装git工具,下面以wins系统为例子说明 https://git-scm.com/downloads wins安装好后ÿ…...

Springboot整合Elasticsearch 7.X 复杂查询
这里使用Springboot 2.7.12版本,Elasticsearch为7.15.0。 导入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId></dependency> yaml文件配置…...

第5课 使用openCV捕获摄像头并实现预览功能
这节课我们开始利用ffmpeg和opencv来实现一个rtmp推流端。推流端的最基本功能其实就两个:预览画面并将画面和声音合并后推送到rtmp服务器。 一、FFmpeg API 推流的一般过程 1.引入ffmpeg库:在代码中引入ffmpeg库,以便使用其提供的功能。 2.捕获摄像头…...
Python3操作Json文件碰到的几个问题
文章目录 小结问题及解决byte数组与str字符串之间不兼容没有Index属性JSON.DUMP(S) & JSON.LOAD(S) 参考 小结 使用Python3操作Json文件碰到的几个问题,进行了解决。 问题及解决 byte数组与str字符串之间不兼容 以下的几个问题都是由于字节数组和字符串之间…...

idea大量爆红问题解决
问题描述 在学习和工作中,idea是程序员不可缺少的一个工具,但是突然在有些时候就会出现大量爆红的问题,发现无法跳转,无论是关机重启或者是替换root都无法解决 就是如上所展示的问题,但是程序依然可以启动。 问题解决…...

springboot 百货中心供应链管理系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,百货中心供应链管理系统被用户普遍使用,为方…...

【WiFi帧结构】
文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...

聊聊 Pulsar:Producer 源码解析
一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台,以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中,Producer(生产者) 是连接客户端应用与消息队列的第一步。生产者…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...
2023赣州旅游投资集团
单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

AI,如何重构理解、匹配与决策?
AI 时代,我们如何理解消费? 作者|王彬 封面|Unplash 人们通过信息理解世界。 曾几何时,PC 与移动互联网重塑了人们的购物路径:信息变得唾手可得,商品决策变得高度依赖内容。 但 AI 时代的来…...
动态 Web 开发技术入门篇
一、HTTP 协议核心 1.1 HTTP 基础 协议全称 :HyperText Transfer Protocol(超文本传输协议) 默认端口 :HTTP 使用 80 端口,HTTPS 使用 443 端口。 请求方法 : GET :用于获取资源,…...

Linux nano命令的基本使用
参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时,显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...