如何优化数据库中的数据表
发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!介绍当进行分页时,MySQL
千家信息网最后更新 2025年01月21日如何优化数据库中的数据表
这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!
介绍
当进行分页时,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安全错误
数据库的锁怎样保障安全
提供软件开发服务怎么开票
网络安全由什么部门管
江阴dell服务器维修站
网络安全法律法规施行时间
ETC缴费下载什么软件开发票
安全的香港服务器托管公司
联迪云音箱服务器设置
mc基岩版手机端服务器
arma3进服务器一直加载
dota服务器连接超时
我的世界钓鱼机手机版服务器
数据库管理和处理
江苏信息化软件开发销售
3年软件开发跳槽薪资
软件开发员工绩效考核表模板
lol新加坡玩什么服务器
东南亚做软件开发
数据库如何应用索引
数据库的数据模型怎么写
网络安全是学校发展的重要
软件开发红冲线
用友服务器安全吗
网络安全m是什么意思
9月网络安全法宣传日
ping 不通服务器
湛江大数据软件开发工程师
网安小兵网络安全
软件开发项目研究技术路线
我的世界服务器怎么管理后台
路UK登陆的时候访问数据库错误