千家信息网

如何优化数据库中的数据表

发表于:2024-11-11 作者:千家信息网编辑
千家信息网最后更新 2024年11月11日,这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!介绍当进行分页时,MySQL
千家信息网最后更新 2024年11月11日如何优化数据库中的数据表

这篇文章主要讲解了"如何优化数据库中的数据表",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何优化数据库中的数据表"吧!

介绍

当进行分页时,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安全错误 数据库的锁怎样保障安全 腾讯云服务器标准和轻量什么区别 机器人rpa软件开发公司 2021江西高校网络安全大赛 服务器ip连不到 网络技术大一实训小结 odf开源数据库论坛 浅谈企业网络安全 软件开发国家要求标准文件 数据库服务器参数 岗山软件开发公司 网络安全审计和入侵检测 上海宝信软件开发股份有限公司 红蜻蜓截屏软件开发商 奇瑞商用车软件开发 腾讯云服务器手机端登录 以后是网络社会 网络安全谁去做 地下城服务器喇叭怎么出售 北京运营网络技术咨询概况 手机什么架服务器 黑客通过什么手段攻击企业服务器 平安财产 网络安全险 长沙喜智软件开发有限公司 手机浏览器服务器安全狗关掉 北京品质软件开发热线 qgis数据库中更新数据 天猫小店软件开发人是谁 北京外企网络技术有限公司 mysql数据库退出指令 宁波云软件开发需要学什么 软件开发一般用哪个平台好
0