如何优化数据库中的数据表
发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!介绍当进行分页时,MySQL
千家信息网最后更新 2024年09月22日如何优化数据库中的数据表
这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!
介绍
当进行分页时,MySQL 并不是跳过 offset 行,而是取 offset+N 行,然后放弃前 offset 行,返回 N 行。例如 limit 10000, 20。mysql排序取出10020条数据后,仅返回20条数据,查询和排序的代价都很高。那当 offset 特别大的时候,效率就非常的低下,所以我们要对sql进行改写
使用书签
用书签记录上次取数据的位置,过滤掉部分数据
如下面语句
SELECT id, name, description FROM film ORDER BY name LIMIT 1000, 10;
可以改为
SELECT id, name, description FROM film WHERE name > 'begin' ORDER BY name LIMIT 10;
name为上次分页后的最大值,注意这种场景只适用于不存在重复值的场景。
延迟关联
延迟关联:通过使用覆盖索引查询返回需要的主键,再根据主键关联原表获得需要的数据
SELECT id, name, description FROM film ORDER BY name LIMIT 100,5;
id是主键值,name上面有索引。这样每次查询的时候,会先从name索引列上找到id值,然后回表,查询到所有的数据。可以看到有很多回表其实是没有必要的。完全可以先从name索引上找到id(注意只查询id是不会回表的,因为非聚集索引上包含的值为索引列值和主键值,相当于从索引上能拿到所有的列值,就没必要再回表了),然后再关联一次表,获取所有的数据
因此可以改为
SELECT film.id, name, description FROM film JOIN (SELECT id from film ORDER BY name LIMIT 100,5) temp ON film.id = temp.id
倒序查询
假如查询倒数最后一页,offset可能回非常大
SELECT id, name, description FROM film ORDER BY name LIMIT 100000, 10;
改成倒序分页,效率是不是快多了?
SELECT id, name, description FROM film ORDER BY name DESC LIMIT 10;
感谢各位的阅读,以上就是"如何优化数据库中的数据表"的内容了,经过本文的学习后,相信大家对如何优化数据库中的数据表这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
数据
索引
查询
数据库
数据表
关联
学习
必要
书签
倒序
内容
场景
效率
时候
延迟
排序
低下
最大
代价
位置
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发之后位移
软件开发与测试有前途吗
lol手游转换服务器
合肥风雨兼程软件开发公司
计算机网络技术可考取的证书
江西中汇网络技术公司怎么样
sql数据库数据升级
外国网络安全的法律法规
地铁逃生如何把服务器改成亚服
东营戴尔服务器代理客服电话
大数据云数据库厂商及其代表产品
网络安全沙龙主题
软件开发计划可重用产品
csgo服务器社区
软件开发工程师用日语怎么说
软件开发考试成绩查询
数据库优化问题
ping服务器ip不通
用类方法创建数据库
软件开发经典例题
网络安全练兵
软件开发岗位招聘方法
如何搭建饥荒联机版服务器
数据库查询在哪里
网络技术转让行业标准
全球根服务器
网络技术起源于谁
软件开发的三个方向
供应实时数据库系统多少钱
oracle查询数据库名6