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

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

目录

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语句

    -- 创建视图
    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表数据的时候,把被删数据保存起来,以便后面进行数据恢复

  • 创建触发器

    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条

每页显示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

相关文章:

  • 深入解析汽车MCU的软件架构
  • grafana table合并查询
  • 从零开始:神经网络(2)——MP模型
  • 编程笔记 html5cssjs 007 文章排版 颜真卿《述张长史笔法十二意》
  • lambda有先后顺序
  • el根据需求合并列
  • 基于php的用户登录实现(v2版)(持续迭代)
  • [贰],万能开篇HelloWorld
  • linux多线程编程使用互斥量的原理分析和应用实例
  • 数据结构之顺序表及其实现!
  • 提示词微调:LLMs适应新任务的强大技术
  • 解释 Git 的基本概念和使用方式。
  • openssl3.2 - exp - 可以在命令行使用的口令算法名称列表
  • Pytorch学习 day08(最大池化层、非线性激活层、正则化层、循环层、Transformer层、线性层、Dropout层)
  • (已解决)报错:Could not load the Qt platform plugin “xcb“
  • 《深入 React 技术栈》
  • 【EOS】Cleos基础
  • 2017 年终总结 —— 在路上
  • Android开源项目规范总结
  • Hibernate最全面试题
  • ng6--错误信息小结(持续更新)
  • OSS Web直传 (文件图片)
  • Redis 中的布隆过滤器
  • 代理模式
  • 关于for循环的简单归纳
  • 机器学习学习笔记一
  • 前端每日实战:61# 视频演示如何用纯 CSS 创作一只咖啡壶
  • 如何在 Tornado 中实现 Middleware
  • 使用 5W1H 写出高可读的 Git Commit Message
  • 算法---两个栈实现一个队列
  • FaaS 的简单实践
  • Nginx实现动静分离
  • 积累各种好的链接
  • ###51单片机学习(1)-----单片机烧录软件的使用,以及如何建立一个工程项目
  • #{}和${}的区别?
  • #pragma pack(1)
  • ( )的作用是将计算机中的信息传送给用户,计算机应用基础 吉大15春学期《计算机应用基础》在线作业二及答案...
  • (day6) 319. 灯泡开关
  • (二)七种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (一)RocketMQ初步认识
  • ./configure,make,make install的作用(转)
  • .NET Windows:删除文件夹后立即判断,有可能依然存在
  • .net6解除文件上传限制。Multipart body length limit 16384 exceeded
  • .net反编译工具
  • /usr/bin/perl:bad interpreter:No such file or directory 的解决办法
  • @data注解_SpringBoot 使用WebSocket打造在线聊天室(基于注解)
  • @Tag和@Operation标签失效问题。SpringDoc 2.2.0(OpenApi 3)和Spring Boot 3.1.1集成
  • []C/C++读取串口接收到的数据程序
  • [202209]mysql8.0 双主集群搭建 亲测可用
  • [Android] Upload package to device fails #2720
  • [Angular 基础] - 指令(directives)
  • [CDOJ 1343] 卿学姐失恋了
  • [C语言]——C语言常见概念(1)
  • [javaSE] GUI(Action事件)
  • [java基础揉碎]方法的重写/覆盖