当前位置: 首页 > article >正文

学习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

四、拓展补充

五、结语

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

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

相关文章:

学习MySQL的第八天

海到无边天作岸 山登绝顶我为峰 一、数据库的创建、修改与删除 1.1 引言 在经过前面七天对于MySQL基本知识的学习之后,现在我们从基本的语句命令开始进入综合性的语句的编写来实现特定的需求,从这里开始需要我们有一个宏观的思想&…...

AI识别与雾炮联动:工地尘雾治理新途径

利用视觉分析的AI识别用于设备联动雾炮方案 背景 在建筑工地场景中,人工操作、机械作业以及环境因素常常导致局部出现大量尘雾。传统监管方式存在诸多弊端,如效率低、资源分散、监控功能单一、人力效率低等,难以完美适配现代工程需求。例如…...

GD32F303-IAP的过程和实验

使用的芯片为GD32F303VC 什么是IAP呢?有个博主写的很清楚;就是远程升级; 【单片机开发】单片机的烧录方式详解(ICP、IAP、ISP)_isp烧录-CSDN博客 我们需要写一个boot 和APP 通过 boot对APP的程序进行更新&#xf…...

众趣科技助力商家“以真示人”,让消费场景更真实透明

在当今的消费环境中,消费者权益保护问题日益凸显。无论是网购商品与实物不符、预定酒店民宿与图文描述差异大,还是游览景区遭遇“照骗”,这些问题不仅让消费者在消费和决策过程中倍感困扰,也让商家面临信任危机。 消费者在享受便…...

spark core编程之行动算子、累加器、广播变量

一、RDD 行动算子 reduce:聚集 RDD 所有元素,先聚合分区内数据,再聚合分区间数据。 collect:在驱动程序中以数组形式返回数据集所有元素。 foreach:分布式遍历 RDD 元素并调用指定函数。 count:返回 RDD…...

提高课:数据结构之树状数组

1&#xff0c;楼兰图腾 #include<iostream> #include<cstring> #include<cstdio> #include<algorithm>using namespace std;typedef long long LL;const int N 200010;int n; int a[N]; int tr[N]; int Greater[N], lower[N];int lowbit(int x) {ret…...

基于javaweb的SpringBoot新闻视频发布推荐评论系统(源码+部署文档)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…...

使用Go语言实现自动清理应用系统日志

在服务器上部署业务应用系统&#xff0c;每天都会产生大量的日志&#xff0c;随着时间的推移&#xff0c;日志越积累越多&#xff0c;占用了大量的磁盘空间&#xff0c;除了可以手动清理日志外&#xff0c;还可以通过程序实现自动清理日志。 之所以选择Go语言&#xff0c;是因…...

机器学习之PCA主成分分析详解

文章目录 引言一、PCA的概念二、PCA的基本数学原理2.1 内积与投影2.2 基2.3 基变换2.4 关键问题及优化目标2.5 方差2.6 协方差2.7 协方差矩阵2.8 协方差矩阵对角化 三、PCA执行步骤总结四、PCA计算实例五、PCA参数解释六、代码实现七、PCA的优缺点八、总结 引言 在机器学习领域…...

回溯——固定套路 | 面试算法12道

目录 输出二叉树所有路径 路径总和问题 组合总和问题 分割回文串 子集问题 排列问题 字母大小写全排列 单词搜索 复原IP地址 电话号码问题 括号生成问题 给我一种感觉是回溯需要画图思考是否需要剪枝。 元素个数n相当于树的宽度&#xff08;横向&#xff09;&#x…...

【11】Strongswan processor 详解1

processor_t结构体&#xff0c;声明了一些公用方法&#xff1a; get_total_threads获取总的线程数量&#xff1b; get_idle_threads获取空闲线程数量&#xff1b; get_working_threads按指定的优先级获取处理该优先级的job的线程数量&#xff1b; get_job_load 或取指定优先级j…...

Maven和MyBatis学习总结

目录 Maven 1.Maven的概念&#xff1a; 2.在具体的使用中意义&#xff1a; 3.与传统项目引入jar包做对比&#xff1a; 传统方式&#xff1a; 在maven项目当中&#xff1a; 4.在创建maven项目后&#xff0c;想要自定义一些maven配置 5.maven项目的结构 6.maven指令的生…...

普通通话CSFB方式(2g/3g)

一、CSFB的触发条件 当模块&#xff08;或手机&#xff09;驻留在 4G LTE网络 时&#xff0c;若发生以下事件&#xff0c;会触发CSFB流程&#xff1a; 主叫场景&#xff1a;用户主动拨打电话。被叫场景&#xff1a;接收到来电&#xff08;MT Call&#xff09;。紧急呼叫&…...

揭开人工智能与机器学习的神秘面纱:开发者的视角

李升伟 编译 人工智能&#xff08;AI&#xff09;和机器学习&#xff08;ML&#xff09;早已不再是空洞的流行语——它们正在彻底改变我们构建软件、做出决策以及与技术互动的方式。无论是自动化重复性任务&#xff0c;还是驱动自动驾驶汽车&#xff0c;AI/ML都是现代创新的核…...

AndroidTV 当贝播放器-v1.5.2-官方简洁无广告版

AndroidTV 当贝播放器 链接&#xff1a;https://pan.xunlei.com/s/VONXRf0g3cT0ECVt6GEsoODFA1?pwds4qv# AndroidTV 当贝播放器-v1.5.2-官方简洁无广告版...

BERT - MLM 和 NSP

本节代码将实现BERT模型的两个主要预训练任务&#xff1a;掩码语言模型&#xff08;Masked Language Model, MLM&#xff09; 和 下一句预测&#xff08;Next Sentence Prediction, NSP&#xff09;。 1. create_nsp_dataset 函数 这个函数用于生成NSP任务的数据集。 def cr…...

Python生成exe

其中的 -w 参数是 PyInstaller 用于窗口模式&#xff08;Windowed mode&#xff09;&#xff0c;它会关闭命令行窗口的输出&#xff0c;这通常用于 图形界面程序&#xff08;GUI&#xff09;&#xff0c;比如使用 PyQt6, Tkinter, PySide6 等。 所以&#xff1a; 如果你在没有…...

MySql 自我总结

目录 1. 数据库约束 1.1约束类型 2. 表的设计 2.1 一对一 2.2 一对多 2.3 多对多 3. 新增 4. 查询 4.1 聚合查询 4.2 GROUP BY 4.3 HAVING 4.4 联合查询 4.5 内连接 4.5.1 内连接的核心概念 4.5.2 内连接的语法 4.5.3 ON 与 WHERE 的区别 4.6 自连接 4.6.1 定…...

uni-app app 安卓和ios防截屏

首先可参考文档 uni.setUserCaptureScreen 这里需要在项目中引入这个插件 uni-usercapturescreen - DCloud 插件市场 否则会报错,在需要防止截屏录屏的页面中,加入 uni.setUserCaptureScreen({enable: false,success() {console.log(全局截屏录屏功能已禁用);},fail(err)…...

Android Input——查找并添加目标窗口(七)

在 Android 输入系统中,InputDispatcher 的核心职责之一是将输入事件正确地传递到目标窗口。上一篇文章我们介绍到 InputDispatcher 事件分发调用到 findFocusedWindowTargetsLocked() 函数查找焦点窗口,并将焦点窗口添加到目标窗口,这里我们继续往下看。 一、获取焦点窗口…...

ruby内置全局变量

以下是 Ruby 中常见的 内置全局变量 及其用途的详细说明。这些变量以 $ 开头&#xff0c;由 Ruby 解释器自动管理&#xff0c;用于访问系统状态、异常、输入输出等核心信息。 一、异常处理相关 全局变量说明示例$!当前作用域最后抛出的异常对象&#xff08;等同于 rescue >…...

pytorch查询字典、列表维度

输出tensor变量维度 print(a.shape)输出字典维度 for key, value in output_dict.items():if isinstance(value, torch.Tensor):print(f"{key} shape:", value.shape)输出列表维度 def get_list_dimensions(lst):# 基线条件&#xff1a;如果lst不是列表&#xff0…...

【Go】windows下的Go安装与配置,并运行第一个Go程序

【Go】windows下的Go安装与配置&#xff0c;并运行第一个Go程序 安装环境&#xff1a;windows10 64位 安装版本&#xff1a;go1.16 windows/amd64 一、安装配置步骤 1.到官方网址下载安装包 https://golang.google.cn/dl/ 默认情况下 .msi 文件会安装在 c:\Go 目录下。可自行配…...

Windows上使用Qt搭建ARM开发环境

在 Windows 上使用 Qt 和 g++-arm-linux-gnueabihf 进行 ARM Linux 交叉编译(例如针对树莓派或嵌入式设备),需要配置 交叉编译工具链 和 Qt for ARM Linux。以下是详细步骤: 1. 安装工具链 方法 1:使用 MSYS2(推荐) MSYS2 提供 mingw-w64 的 ARM Linux 交叉编译工具链…...

CNN(卷积神经网络)

什么是CNN CNN&#xff08;卷积神经网络&#xff09;&#xff0c;是通过提取特征来压缩计算的一个网络结构&#xff0c;主要由卷积层、池化层、全连接层组成。 卷积层 在卷积层中&#xff0c;通过卷积核的移动对不同的区域提取特征生成一个新的矩阵&#xff0c;比如一个原始…...

Linux 内核网络协议栈中的 struct packet_type:以 ip_packet_type 为例

在 Linux 内核的网络协议栈中,struct packet_type 是一个核心数据结构,用于注册特定协议类型的数据包处理逻辑。它定义了如何处理特定协议的数据包,并通过协议类型匹配机制实现协议分发。本文将通过分析 ip_packet_type 的定义和作用,深入探讨其在网络协议栈中的重要性。 …...

网络问题之TCP/UDP协议

1. TCP是什么&#xff1f; TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是互联网核心协议之一&#xff0c;属于传输层协议&#xff0c;为应用程序提供可靠的、面向连接的字节流服务。 基本特性 可靠性&#xff1a;通过确认机制、重传机…...

vue3腾讯云直播 前端拉流(前端页面展示直播)

1、引入文件&#xff0c;在index.html <link href"https://tcsdk.com/player/tcplayer/release/v5.3.2/tcplayer.min.css" rel"stylesheet" /><!--播放器脚本文件--><script src"https://tcsdk.com/player/tcplayer/release/v5.3.2/t…...

【MYSQL从入门到精通】数据库基础操作、数据类型

目录 一些基础操作语句 创建库名 选择要操作的数据库 删除数据库 磁盘中删除文件的原理 数据库安全的各种措置 查看MYSQL的帮助 数值类型 字符串类型 日期类型 一些基础操作语句 1.使用客户端工具连接数据库服务器&#xff1a;mysql -uroot -p 2.查看所有数据库&am…...

JS里对于集合的简单介绍

JS的集合 前言一、集合二、基本使用1. 创建集合2. 添加元素3. 删除元素4. 检查元素5. 清空集合6. 集合的大小 三、扩展使用1. 遍历集合2. 从数组创建集合3. 集合的应用场景 四、总结 前言 JS里对于集合的简单介绍 同数学的集合&#xff0c;有无序性、唯一性 注意&#xff1a;…...