学习MySQL的第八天

海到无边天作岸                 

             山登绝顶我为峰

一、数据库的创建、修改与删除

1.1 引言

        在经过前面七天对于MySQL基本知识的学习之后,现在我们从基本的语句命令开始进入综合性的语句的编写来实现特定的需求,从这里开始需要我们有一个宏观的思想,来俯瞰SQL命令

数据存储过程​​​​​
1.2 创建数据库

        创建数据库是所有命令开始,而创建数据库我们有三种方法

方式1:
CREATE DATABASE The_First
方式2:
# 指定一个特定的字符集,你可以使用 CREATE DATABASE 语句,并使用 CHARACTER SET 选项来指定字符集。
CREATE DATABASE The_First_2 CHARACTER SET utf8mb4
方式3:
#创建一个数据库,如果它存在,则创建失败,但是不报错
CREATE DATABASE IF NOT EXISTS The_First CHARACTER SET 'gbk'


1.3 管理数据库

        通过 SHOW DATABASES 来实现对全部数据库和指定数据库的查询和显示

查看所有数据库信息
SHOW DATABASES
查看指定数据库信息
SHOW CREATE DATABASE The_first
全部数据库
指定数据库

        通过 USE 来实现数据库的切换,并使用 SHOW TABLES 查看当前数据库中保存的数据表,以及通过 SELECT DATABASE() 语句来查看当下使用的数据库是哪一个

# 切换数据库
USE mysql
# 查看当前数据库中保存的数据表
SHOW TABLES
# 查看当前使用的数据库
SELECT DATABASE()
FROM DUAL;# 查看指定数据库下保存的数据表
SHOW TABLES FROM mysql
切换数据库​​​​​
查看当前数据库中保存的数据表
查看当前使用的数据库
查看指定数据库下保存的数据表
1.4 修改数据库

        当数据库建立好之后,我们可能会需要对其中的信息进行修改,比如:更改数据库字符集

SHOW CREATE DATABASE the_first
ALTER DATABASE the_first CHARACTER SET 'gbk'
修改前

修改后

        小发现: 在我的电脑上可以,不知道在你的上面是否可行,但是不要轻易尝试;reset master 清楚日志缓存,然后重新建立刚刚被删除的表,已保存的数据就恢复,这是在我的电脑上可以实现的;具体原理我现在还无法理解

二、表的创建、修改、查询

2.1 如何创建表

        当你想要创建一个表时,一定要指明是在哪个数据库创建的表

        注意:

        (1)如果创建表时没有明确指明使用的字符集,则默认最近使用的字符集

        (2)使用VARCHAR来定义字符串,必须在使用VARCHAR时指明其长度

        (3)用户需要具备管理员权限

        方式1: 

CREATE TABLE IF NOT EXISTS departments( 
id INT,
name VARCHAR (255),
hire_data DATE
);# 查看表结构
DESC departments

        方式2:基于现有的表创建新的表

CREATE TABLE the_first_3
AS 
SELECT id,name
FROM departments;SELECT *
FROM the_first_3



        补充:查询字段中的别名可以作为新创建的表的字段的名称

CREATE TABLE the_first_4
AS
SELECT e.id '工号',e.name '姓名',t.position '职位'
FROM departments e JOIN department_position t
ON e.id = t.idSELECT *
FROM the_first_4DESC the_first_4




        练习:

创建一个表emp1,实现对 departments表的复制,但不包含表数据
CREATE TABLE emp1
SELECT *
FROM departments
LIMIT 0;

2.2 修改表

        通过 ALTER TABLE 来实现对表的修改,以及通过DESC 来实现表的显示

DESC the_first_4;

        2.2.1 添加一个字段

        如果不加以说明,那么默认添加到最后一个字段

# 添加一个字段
ALTER TABLE the_first_4
ADD salary DOUBLE (10,2)# 指定添加位置
ALTER TABLE the_first_4
ADD phone_number VARCHAR(12) FIRST

        2.2.2 添加字段到指定位置

        补充:列名不能用单引号进行引用

ALTER TABLE the_first_4
ADD email VARCHAR(45) AFTER 姓名;

2.3 修改一个字段: 数据类型、长度

        一般不会对数据类型进行修改,因为大概率会导致出错,不过我们通常会对长度进行修改

# 修改长度
ALTER TABLE the_first_4
MODIFY `姓名` VARCHAR(300);
DESC the_first_4;

        修改默认值:如果没有输入值,那么就默认为 NO,对于在修改前插入的没有影响

ALTER TABLE the_first_4
MODIFY salary VARCHAR(100) DEFAULT 'NO';
DESC the_first_4;
SELECT *
FROM the_first_4

2.4 重命名和删除

        重命名和删除既可以用于字段也可以用于表等

# 重命名一个字段
ALTER TABLE the_first_4
CHANGE salary month_salary DOUBLE(10,2);
SELECT *
FROM the_first_4;# 删除一个字段
ALTER TABLE the_first_4
DROP phone_number
# 或 DROP COLUMN phone_number
SELECT *
FROM the_first_4;

        对于重命名表和重命名字段的区别基本相同,而删除表会将表的结构和数据全部都删除掉,清空表是清空表中的所有数据,但是表结构保留,代码在下面,大家可以自行尝试

# 重命名表
# 方式1:
RENAME TABLE the_first_4
TO the_first_one
# 方式2:
ALTER TABLE the_first_one
RENAME TO the_first_4# 删除表
# 将表的结构和数据全部都删除掉
DROP TABLE the_first_3# 清空表
# 清空表中的所有数据,但是表结构保留
CREATE TABLE the_first_3
AS
SELECT id,`name`
FROM departmentsTRUNCATE TABLE the_first_3
SELECT * FROM the_first_3

三、DCL中的 COMMIT 和 ROLLBACK

        3.1 注意:

        (1) COMMIT: 提交数据,一旦执行之后,数据就被永久的保存到数据库之中,并且数据不能被回滚(撤销)
        (2) ROLLBACK:执行回滚操作,执行之后可以实现数据的回滚,回滚到最近的 COMMIT操作

        3.2 补充:对比 TRUNCATE TABLE 和 DELETE FROM
        (1) 相同点:都可以实现对表中所有数据的删除,同时保留表结构。
        (2) 不同点:TRUNCATE TABLE:一旦执行此操作,表数据全部清除。同时,数据是不可以回滚的。
        (3) DELETE FROM: 一旦执行此操作,表数据可以全部清除(不带WHERE)。同时,数据是可以实现回滚
        3.3 DDL 和 DML 的说明

        (1) DDL的操作一旦执行,就不可回滚。指令SET autocommit=FALSE对DDL操作失效。因为在执行完DDL之后,一定会进行一次COMMIT,所以无法回滚
        (2) DML的操作默认情况,一旦执行,也是不可回滚的。但是,如果在执行DML之前,执行了 SET autocommit = FALSE ,则执行的DML操作就可以实现回滚。

# 演示:
CREATE TABLE the_first_2
AS
SELECT *
FROM the_first_4
1.
COMMIT;
2.
SELECT *
FROM the_first_2
3.
SET autocommit = FALSE;
4.
DELETE FROM the_first_2
5.
SELECT *
FROM the_first_2
6.
ROLLBACK;
7.
SELECT *
FROM the_first_2# TRUNCATE
CREATE TABLE the_first_1
AS
SELECT *
FROM the_first_4
1.
COMMIT; # 保存
2.
SELECT *
FROM the_first_1
3.
SET autocommit = FALSE;
4.
TRUNCATE TABLE the_first_1
5.
SELECT *
FROM the_first_1
6.
ROLLBACK;
7.
SELECT *
FROM the_first_1
# TRUNCATE 无法恢复之前的数据
        3.4 DDL 原子化
CREATE DATABASE the
USE the
CREATE TABLE book(
id INT,
`name` VARCHAR(255)
);
SHOW TABLES

        3.5 小结

        因为book1 不存在,所以无法执行,这个语句可以看作是一个事务,如果不能贯彻完成,那么就撤销语句中对已经完成的操作,例:

DROP TABLE book,book1;
SHOW TABLES

四、拓展补充

五、结语

        若你渴望一首春日的诗,不妨听听《春暖花开》的旋律:「生命如水有时平静,也有时澎湃,穿越阴霾,阳光洒满你窗台」‌

须知少日拏云志,曾许人间第一流。我们还年轻,我们还有无限可能!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/75586.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux-内核驱动-中断-key

DEV_NAME:设备名称。 wg:等待队列头,用于同步。 condition:条件变量,用于等待和唤醒。 中断处理函数 irq_handler:处理中断请求,设置条件变量并唤醒等待队列中的进程。 文件操作函数 open…

asm汇编源代码之按键处理相关函数

提供5个子程序: 1. 发送按键 sendkey 2. 检测是否有按键 testkey 3. 读取按键 getkey 4. 判断键盘缓冲区是否为空 bufempty 5. 判断键盘缓冲区是否已满 buffull 具体功能及参数描述如下 sendkey proc  far ; axcharcode testkey proc  far ; out: ;   zf1 buff empt…

Java Collections 类中常用方法使用

一、Collections类 java.util.Collections 类是 Java 集合框架中的一个工具类,提供了一系列静态方法来操作和处理各种类型的集合。这些方法简化了对集合进行排序、查找、同步控制、创建只读集合等常见操作的过程。 二、常用方法 方法类别‌‌方法签名‌‌功能‌‌需…

Linux网络编程——数据链路层详解,以太网、MAC地址、MTU、ARP、DNS、NAT、代理服务器......

目录 一、前言 二、以太网 二、以太网帧格式 三、 MAC地址 四、MTU 1、数据链路层的数据分片 2、MTU对UDP协议的影响 3、MTU对TCP协议的影响 五、ARP协议 1、什么是ARP 2、ARP的作用 3、ARP协议的工作流程 4、ARP缓存表 5、ARP请求报文 6、中间人 六、DNS&…

轻量级开源文件共享系统PicoShare本地部署并实现公网环境文件共享

## 前言 本篇文章介绍,如何在 Linux 系统本地部署轻量级文件共享系统 PicoShare,并结合 Cpolar 内网穿透实现公网环境远程传输文件至本地局域网内文件共享系统。 PicoShare 是一个由 Go 开发的轻量级开源共享文件系统,它没有文…

基于查表法的 CRC8 / CRC16 / CRC32校验解析

在嵌入式开发中,CRC(Cyclic Redundancy Check)循环冗余校验算法广泛应用于通信数据校验、Flash 数据完整性检测、Bootloader 升级验证等场景。本文将深入剖析一套完整的 CRC8、CRC16 和 CRC32 实现,并通过查表法(Table…

二战蓝桥杯所感

🌴 前言 今天是2025年4月12日,第十六届蓝桥杯结束,作为二战的老手,心中还是颇有不甘的。一方面,今年的题目比去年简单很多,另一方面我感觉并没有把能拿的分都拿到手,这是我觉得最遗憾的地方。不…

基于ueditor编辑器的功能开发之给编辑器图片增加水印功能

用户需求,双击编辑器中的图片的时候,出现弹框,用户可以选择水印缩放倍数、距离以及水印所放置的方位(当然有很多水印插件,位置大小透明度用户都能够自定义,但是用户需求如此,就自己写了&#xf…

算法题(123):回文日期

审题: 本题需要我们判断以八位数确定的日期范围中是否存在回文数 思路: 方法一:枚举法 1.确定枚举对象: 对象1:八位数日期,所需枚举次数:10^8 对象2:年,所需枚举次数&…

数据库表的操作

一、数据库的搭建 如上篇文章 二、基础了解 show命令支持模糊匹配 show databases、show tables、 show databases like “” “%”、“_”通配符字符串 三、MySQL数据库表的操作 关系型数据库都是遵循SQL语法进行数据查询和管理的 3.1 SQL介绍 3.1.1 SQL的功能 结构化查询语…

在 Lua 中实现 JSON 与 Table 的相互转换的详细使用方法

在 Lua 中实现 JSON 与 Table 的相互转换是常见的数据序列化需求。以下是详细的实现方案、性能优化技巧及进阶用法: 在 Lua 中实现 JSON 与 Table 的相互转换的详细使用方法-目录 一、常用 JSON 库对比二、基础转换实现1. 使用 lua-cjson(高性能 C 库&am…

dbVisitor 规则怎么用?

在数据库操作中,dbVisitor 是一个功能强大的工具,其规则的使用大大简化了 SQL 语句的编写过程。下面将详细介绍 dbVisitor 规则的使用方法并附上具体例子。 一、规则的基本调用 在 dbVisitor 中,SQL 语句可以通过 {...} 的形式来调用规则&a…

Kingbase 常用运维命令总结

一、数据库连接与基础操作 连接指定服务器数据库 ksql -h 主机IP -p 端口号 -U 用户名 -d 数据库名 -W # 示例:连接 IP 为 192.168.1.100 的数据库 ksql -h 192.168.1.100 -p 54321 -U system -d test -W 断开数据库连接 \q 或 exit 查看数据库列表及详细信息…

【数据结构与算法】LRU Cache 算法实现

文章目录 Ⅰ. 什么是 LRU CacheⅡ. LRU Cache 的实现[146. LRU 缓存](https://leetcode.cn/problems/lru-cache/) Ⅰ. 什么是 LRU Cache ​ LRU( Least Recently Used) 是一种淘汰策略的缩写,意思是 最近最少使用,它是一种 Cache…

网页布局汇总

1. 盒模型 容器大小 内容大小 内边距(padding) 边框大小 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0">&l…

打造海外流量矩阵,TikTok云控工具让获客更简单!

跨境获客&#xff0c;始终是无数企业主心中的一道难题。今天&#xff0c;给大家带来一款强大实用的工具——TikTok矩阵云控系统&#xff0c;帮你轻松突破流量瓶颈&#xff0c;实现高效跨境获客&#xff01; 跨国远程操控——苹果手机矩阵云控系统 在正式开始之前&#xff0c;…

MyBatis-plus 快速入门

提示&#xff1a;MyBatis-Plus&#xff08;MP&#xff09;是一个 MyBatis的增强版 文章目录 前言使用MybatisPlus的基本步骤1、引入MybatisPlus依赖代替Mybatis依赖2、定义Mapper接口并继承BaseMapper他是怎么知道哪张表&#xff0c;哪些字段呢 3、实体类注解4、根据需要添加配…

找搭子系统 搭子经济新风口 基于精准匹配的社交新生态探索

一、市场前景&#xff1a;为什么现在需要"找搭子"&#xff1f; 孤独经济爆发 超60%年轻人存在"精准陪伴"需求&#xff08;2024社交报告&#xff09; 传统社交App无法满足"非婚恋、非熟人"的中间态需求 线下活动复苏 剧本杀/飞盘等兴趣活动年增…

深入探析C#设计模式:访问者模式(Visitor Pattern)的原理与应用

引言 在软件开发中&#xff0c;设计模式为我们提供了高效、可维护的解决方案。而在众多设计模式中&#xff0c;访问者模式&#xff08;Visitor Pattern&#xff09;以其独特的结构和应用场景&#xff0c;在复杂系统中发挥着重要作用。本文将深入讲解访问者模式的定义、原理、优…

Redis核心功能实现

前言 学习是个输入的过程&#xff0c;在进行输入之后再进行一些输出&#xff0c;比如写写文章&#xff0c;笔记&#xff0c;或者做一些技术串讲&#xff0c;虽然需要花费不少时间&#xff0c;但是好处很多&#xff0c;首先是能通过输出给自己的输入带来一些动力&#xff0c;然…