【数据库】索引 视图 触发器 分页查询

目录

1、索引

2、视图

3、触发器

4、分页查询⚠️


1、索引

  • 提升查询效率、当数据量小的时候,索引看不出来效果,当数据量很大的时候,索引会显著提高查询速度

  • 当给表添加索引之后,新插入一条数据,就会让索引进行重新排列

    所以,如果频繁的增加或者删除数据,此时 索引的效率不会很高

  • 在创建表的时候,主键会自动的被设置为索引

  • 创建索引:create index 索引的名称 on 表(字段)

    • create index student_index_sname on Student(sname)
  • 删除索引:drop index 索引的名称 on 表

    • drop index student_index_sname on Student

2、视图

  • 可以把一段sql语句保存起来,以后进行查询的时候,可以从视图中查询数据, 相当于一张结果表

  • create view 视图名称 as sql语句

    sql 复制代码
    -- 创建视图
    create view student_sc_course AS
    select s.sid,s.sname,c.cid,c.cname,score from Student s INNER JOIN SC on s.sid = SC.sid inner JOIN Course c on SC.cid = c.cid
    
    -- 使用视图 把视图当成结果表来看
    select sid,avg(score) from student_sc_course group by sid
    
    -- 删除视图
    drop view student_sc_course

3、触发器

  • 触发器可以监控数据库里的表,当表被执行增删改操作的时候,可以执行一些固定的操作

比如,删除student表数据的时候,把被删数据保存起来,以便后面进行数据恢复

  • 创建触发器

    sql 复制代码
    create trigger 触发器名字
    triggerTime  --- before|after
    triggerName  --- insert|update|delete
    on 表 For Each Row
    begin
    ...
    当被触发的时候要做的事
    ...
    End
    
    -- 监控Student
    -- 里面有变量:
    	-- old 原来的数据库里的数据
    	-- new 新来的数据
    
    create trigger stu_t
    create trigger stu_trigger
    before
    delete
    on Student
    for each row
    begin
    	-- old 原来的数据库里的数据
    	-- new 新来的数据
    	insert into Student_copy1(sname,sage,ssex) values(old.sname,old.sage,old.ssex);
    End

4、分页查询⚠️

limit start, length 从start开始,查length条

sql 复制代码
每页显示4条数据
-- 第一页显示 0开始 4条
select * from Student LIMIT 0,4
-- 第二页数据 4号数据开始,4条
select * from Student LIMIT 4,4
......
-- 当前页:n 
-- start:(n-1)*pageSize
-- 每一页显示:pageSize条数据
select * from Student limit (n-1)*pageSize,pageSize
相关推荐
Mahir088 小时前
Redis 与 MySQL 数据同步:一致性保证的完整解决方案
数据库·redis·mysql·缓存·面试·数据一致性
2301_769340678 小时前
如何在 Vuetify 中可靠捕获 Chip 关闭事件(包括键盘触发).txt
jvm·数据库·python
AC赳赳老秦8 小时前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
·醉挽清风·9 小时前
学习笔记—MySQL—库表操作
笔记·学习·mysql
灵犀学长9 小时前
基于 Spring ThreadPoolTaskScheduler + CronTrigger 实现的动态定时任务调度系统
java·数据库·spring
北秋,9 小时前
PostgreSQL(Postgres)数据库基础用法 + 数字型 + 字符型 完整联合注入实战
数据库·postgresql·开源
m0_5967490910 小时前
JavaScript中手动实现一个new操作符的底层逻辑
jvm·数据库·python
多加点辣也没关系10 小时前
Redis 的安装(详细教程)
数据库·redis·缓存
数据库小学妹11 小时前
数据库连接池避坑指南:告别“连接超时”与“资源耗尽”,让系统跑得更快!
数据库·redis·sql·mysql·缓存·dba
dishugj11 小时前
HANA 数据库备份与恢复
数据库·oracle