如何优化数据库中的数据表
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!介绍当进行分页时,MySQL
千家信息网最后更新 2025年11月13日如何优化数据库中的数据表
这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!
介绍
当进行分页时,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安全错误
数据库的锁怎样保障安全
多个系统可以共用服务器吗
pve服务器 永恒岛
江苏汽车网络技术有限公司
手机软件开发者是谁
北京画图软件开发
应用用户和数据库用户
专业版数据库偏移量为的位置执行
深圳嵌入式软件开发中心
软件开发年终奖一般多少
镜像服务器有什么用处
lol 输出数据库
服务器RAIDsas测试
内蒙古数据库
机服务器监控
蓝山县网络安全
iosapp软件开发哪家靠谱
军营网络安全宣传演讲
智能镜子软件开发
思必达网络技术有限公司
在数据库中查询出生日期的人
大型数据库技术简答题
学校计算机与网络安全讲座
上海自动网络技术转让产品
集体潜意识是一个大数据库
数据库这门课怎么学
lol 输出数据库
组态王和mysql数据库
最新的ibm服务器
东莞华合通讯网络技术有限公司
la是哪个地区服务器