MySQL【五】

索引

  • 能让数据库服务器更快地查找和获取表中指定的行。类似于书的目录。
  • 在MySQL中,所有数据类型都可以被索引。
索引的分类
  • 主键索引:方式1:ALTER TABLE 表名 ADD PRIMARY KEY 索引名( 字段名 )

    方式2:创建表的时候指定主键
    ########## 创建名为pk_s的主键索引,主键字段sno ########## alter table s add primary key pk_s(sno);

  • 唯一索引:CREATE UNIQUE INDEX 索引名称 ON 表名(字段名); 或者 ALTER TABLE 表名 ADD UNIQUE (字段名);

  • 组合索引:CREATE INDEX 索引名称 ON 表名(字段1,字段2,字段3); 或者 ALTER TABLE 表名 ADD INDEX 索引名称(字段1,字段2,字段3);
    ########## 创建名为idx_group的组合索引,索引字段addr、sex和dob ########## alter table s add index idx_group(addr,sex,dob);

创建索引
  • 创表时创建普通索引:

CREATE table 表名( 字段声明列表, INDEX [indexName] (字段名) );

  • 建表后创建普通索引:

CREATE INDEX 索引名 on 表名(字段名); 或者 ALTER TABLE 表名 ADD INDEX 索引名称 (字段名);

查看索引

SHOW INDEX FROM 表名 或者 SHOW KEYS FROM 表名

删除索引

ALTER TABLE 表名 DROP INDEX 索引名; 或者 DROP INDEX 索引名 ON 表名

视图

视图就是一个虚拟的表,同真实的数据表一样

视图的分类

简单视图和复杂视图

创建视图

CREATE [OR REPLACE] VIEW <视图名> [<字段名列表>] AS <SELECT语句> [WITH [CASCADED|LOCAL] CHECK OPTION ]

WITH \[CASCADED \| LOCAL CHECK OPTION]:表示视图在更新时保证在视图的权限范围之内;cascade是默认值,表示更新视图的时候,要满足视图和表的相关条件;local表示更新视图的时候,要满足该视图本身定义的条件即可。

sql 复制代码
########## 创建一个名为stavgview的视图,包括所有学生的学号和平均成绩(别名:avg)  ##########
create view stavgview as select sno,avg(score) as avg from sc group by sno;

操作视图

查看视图的结构信息

DESCRIBE 视图名/DESC 视图名;

查看视图定义的文本

SHOW CREATE VIEW 视图名;

删除视图

DROP VIEW IF EXISTS 视图名 [RESTRICT|CASCADE];

删除视图时,只能删除视图的定义,并不会删除数据,CASECADE:表示级联删除。

注意

如果在一个视图中包含了聚合函数、GROUP BY、DISTINCT、UNION(ALL)、HAVING等关键字时,则不能通过该视图进行更新操作。

如果在一个视图中包含了由表达式或常数组成的列,则不能通过该视图进行UPDATE、INSERT操作,但允许执行DELETE操作。

视图定义中包含了子查询,不能更新。

相关推荐
梦想的旅途22 分钟前
企业微信外部群主动调用:RPA 接口与官方 API 的技术边界
网络·mysql·自动化·企业微信·rpa
金融支付架构实战指南6 分钟前
CQRS + 命令模式 + 事件驱动 + 数据库持久化
数据库·ddd·命令模式·领域驱动模型
sevenll0725 分钟前
DocKit agentic MongoDB GUI 客户端 - 用自然语言和你的数据对话
数据库·mongodb·nosql·agent·桌面客户端
智者知已应修善业34 分钟前
【51单片机初始化D5-D8亮,每按键按下D1到D4全亮,再按下恢复,如此循环】2024-3-26
c++·经验分享·笔记·算法·51单片机
团象科技37 分钟前
从一线实操案例拆解不同出海团队落地海外VPS运维独立站的路径细节
大数据·数据库·人工智能
小马爱打代码1 小时前
框架 - 组件 - 中间件:生产级参数配置指引
数据库·中间件
asdfg12589631 小时前
一文通俗理解JDBC中的核心概念+案例
java·数据库·oracle·jdbc
juesdo1 小时前
青岑CTF之 EZPHP系列
笔记·web安全·php
点灯小铭1 小时前
基于单片机与DAC0832的双路波形信号发生系统设计
数据库·单片机·mongodb·毕业设计·课程设计·期末大作业
小陈phd1 小时前
Text2SQL智能体学习笔记(二)——NL2SQL落地的隐形基石:元数据库
数据库·笔记·学习