学习MySQL的第十一天

逆风执炬,向光而行

一、补充

我们首先对之前的文章进行一下补充

1.1 check约束

我们通过具体的案例来对这check约束进行一下讲解

sql 复制代码
CREATE TABLE gardens(
  id INT CHECK(id<10),
  name VARCHAR(255) UNIQUE,
  garden INT DEFAULT 100
);

DESC gardens;

INSERT INTO gardens
VALUES(1,'t',100)

此时,如果你要添加的数据中,id 大于等于10,将会显示插入失败;如果garden没有具体数据,则garden默认为是100

sql 复制代码
INSERT INTO gardens(id,name)
VALUES(2,'p')

INSERT INTO gardens(id,name)
VALUES(40,'t')

SELECT * FROM gardens


Check constraint 'gardens_chk_1' is violated

1.2 在 ALTER TABLE时添加约束

sql 复制代码
ALTER TABLE gardens
MODIFY `name` VARCHAR(255) DEFAULT 'Me'

DESC gardens

1.3 在 CREATE TABLE时删除约束

sql 复制代码
ALTER TABLE gardens
MODIFY `name` VARCHAR(255);
 
DESC gardens

这里的删除其实同样是一种修改

二、视图

2.1 视图的理解

1.视图是一种虚拟表,本身是不具有数据的,占用很少的内存空间,它是SQL中的一个重要概念,可以将视图理解为存储起来的SELECT 语句

2.视图中的select语句涉及到的表,称为基表,针对视图做DML操作,会影响到对应的基表中的数据,反之亦然

3.视图本身的删除,不会导致基表中数据的删除

4.视图的应用场景:针对小型项目,不推荐使用视图

5.视图的优点:简化查询、控制数据访问权限

2.2 创建视图

在 CREATE VIEW语句中嵌入子查询

方式为:CREATE VIEW 视图名称

AS 查询语句

准备工作:

sql 复制代码
    CREATE DATABASE test1;
	USE test1;
	CREATE TABLE emps
	AS
	SELECT *
	FROM emp.departments;
	
	CREATE TABLE depts
	AS
	SELECT *
	FROM emp.department_position;

	SELECT * FROM emps;
	SELECT * FROM depts;

2.3 创建视图

sql 复制代码
	CREATE VIEW empss 
	AS
	SELECT emps.id,emps.`name`,depts.position
	FROM emps,depts

    # 因为这里只是为了展示一下单表的情况,所以就没有加入多表的连接条件

2.4 针对于多表

sql 复制代码
	CREATE VIEW empsss
	AS
	SELECT emps.id,emps.`name`,depts.position
	FROM emps,depts
	WHERE emps.id = depts.id

2.5 添加视图字段的别名

sql 复制代码
	CREATE VIEW empsss(emp1_id,depts_position)
	AS
	SELECT emps.id,depts.position
	FROM emps,depts
	WHERE emps.id = depts.id;

    SELECT * FROM empsss;

2.6 视图的优化

sql 复制代码
	CREATE VIEW emp_dept
	AS
	SELECT CONCAT(emp1.`name`,'(',depts.position,')') '姓名(部门)',emp1.salary
	FROM emp1 JOIN depts ON emp1.id = depts.id;

    SELECT * FROM emp_dept;

2.7 基于视图创建视图

sql 复制代码
 CREATE VIEW f_emp_dept
 AS
 SELECT emp_dept.salary
 FROM emp_dept;

 SELECT * FROM emp_dept;

2.8 查看视图

sql 复制代码
 # 查看数据库的表对象、视图对象
 SHOW TABLES;
 # 查看视图结构
 DESC emp_dept;
 # 查看视图属性信息
 SHOW TABLE STATUS LIKE 'emp_dept'; 
 # 查看视图的详细定义信息
 SHOW CREATE VIEW emp_dept;

查看数据库的表对象、视图对象
查看视图结构


查看视图属性信息
查看视图的详细定义信息

2.9 更新视图中的数据

更新表中的数据会导致视图中的数据改变;同理,更新视图中的数据也会导致表中的数据改变

sql 复制代码
 UPDATE emp_dept
 SET salary = 1000
 WHERE salary IS NULL;
 
 SELECT * FROM emp_dept;

当视图中的字段在及原表中不存在,则不更新视图中的数据

sql 复制代码
 USE test
 CREATE VIEW avg
 AS
 SELECT student.Sname,avg(sc.grade)
 FROM student,sc,course
 WHERE student.Sno = sc.Sno AND sc.`课程号` = course.`课程号`
 GROUP BY student.Sname

在这里进行错误展示

sql 复制代码
 UPDATE avg
 SET avg(sc.grade) = 100
 WHERE Sname = '周九'
 SELECT * FROM avg;

三、结语

风起青萍,浪成微澜

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

相关推荐
计算机毕设VX:Fegn089518 分钟前
计算机毕业设计|基于springboot + vue服装商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·课程设计
遇到困难睡大觉哈哈19 分钟前
HarmonyOS —— Remote Communication Kit 拦截器(Interceptor)高阶定制能力笔记
笔记·华为·harmonyos
风123456789~26 分钟前
【健康管理】第12章 健康信息学 2/2
笔记·考证·健康管理
hetao173383735 分钟前
2025-12-11 hetao1733837的刷题笔记
c++·笔记·算法
喏喏心35 分钟前
深度强化学习:价值迭代与Bellman方程实践
人工智能·python·学习·机器学习
kkkkkkkkk_12011 小时前
【强化学习】06周博磊强化学习纲要学习笔记——第三课下
笔记·学习·强化学习
WX-bisheyuange1 小时前
基于Spring Boot的智慧校园管理系统设计与实现
java·大数据·数据库·毕业设计
白杨SEO营销1 小时前
白杨SEO:看“20步:从0-1做项目的笨办法”来学习如何选一个项目做及经验分享
前端·学习
无所事事的程序员1 小时前
Claude指令学习
学习
学习路上_write1 小时前
AD5293驱动学习
c语言·单片机·嵌入式硬件·学习