SQL语句优化策略介绍

SQL语句优化策略介绍

1、避免全表扫描

对查询进行优化,应尽量避免全表扫描,首先应考虑在where 及order by 涉及的列上建立索引。

2、避免判断null 值

应尽量避免在where 子句中对字段进行null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:

select id from t where num is null

可以在num 上设置默认值0,确保表中num 列没有null 值,然后这样查询:

select id from t where num=0

(免费学习视频教程推荐:mysql视频教程)

3、避免不等值判断

应尽量避免在where 子句中使用!=或操作符,否则引擎将放弃使用索引而进行全表扫描。

4、避免使用or 逻辑

应尽量避免在where 子句中使用or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描,如:

select id from t where num=10 or num=20

可以这样查询:

select id from t where num=10union allselect id from t where num=20

5、慎用in 和not in 逻辑

in 和not in 也要慎用,否则会导致全表扫描,如:

select id from t1 where num in(select id from t2 where id > 10)

此时外层查询会全表扫描,不使用索引。可以修改为:

select id from t1,(select id from t1 where id > 10)t2 where t1.id = t2.id

此时索引被使用,可以明显提升查询效率。

6、注意模糊查询

下面的查询也将导致全表扫描:

select id from t where name like '%abc%'

模糊查询如果是必要条件时,可以使用select id from t where name like ‘abc%’来实现模糊查询,此时索引将被使用。如果头匹配是必要逻辑,建议使用全文搜索引擎(Elastic search、Lucene、Solr 等)。

7、避免查询条件中字段计算

应尽量避免在where 子句中对字段进行表达式操作,这将导致引擎放弃使用索引而进行全表扫描。如:

select id from t where num/2=100

应改为:

select id from t where num=100*2

8、避免查询条件中对字段进行函数操作

应尽量避免在where 子句中对字段进行函数操作,这将导致引擎放弃使用索引而进行全表扫描。如:

select id from t where substring(name,1,3)='abc'--name 以abc 开头的id

应改为:

select id from t where name like 'abc%'

9、WHERE 子句“=”左边注意点

不要在where 子句中的“=”左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引。

灵机语音 灵机语音

灵机语音

灵机语音 56 查看详情 灵机语音

10、组合索引使用

在使用索引字段作为条件时,如果该索引是复合索引,那么必须使用到该索引中的第一个字段作为条件时才能保证系统使用该索引,否则该索引将不会被使用,并且应尽可能的让字段顺序与索引顺序相一致。

11、不要定义无异议的查询

不要写一些没有意义的查询,如需要生成一个空表结构:

select col1,col2 into #t from t where 1=0

这类代码不会返回任何结果集,但是会消耗系统资源的,应改成这样:

create table #t(...)

12、exists

很多时候用exists 代替in 是一个好的选择:

select num from a where num in(select num from b)

用下面的语句替换:

select num from a where exists(select 1 from b where num=a.num)

13、索引也可能失效

并不是所有索引对查询都有效,SQL 是根据表中数据来进行查询优化的,当索引列有大量数据重复时,SQL 查询可能不会去利用索引,如一表中有字段sex,male、female 几乎各一半,那么即使在sex 上建了索引也对查询效率起不了作用。

14、表格字段类型选择

尽量使用数字型字段,若只含数值信息的字段尽量不要设计为字符型,这会降低查询和连接的性能,并会增加存储开销。

这是因为引擎在处理查询和连接时会逐个比较字符串中每一个字符,而对于数字型而言只需要比较一次就够了。尽可能的使用varchar 代替char ,因为首先可变长度字段存储空间小,可以节省存储空间,其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。

15、查询语法中的字段

任何地方都不要使用select * from t ,用具体的字段列表代替“*”,不要返回用不到的任何字段。

16、索引无关优化

不使用*、尽量不使用union,union all 等关键字、尽量不使用or 关键字、尽量使用等值判断。表连接建议不超过5 个。如果超过5 个,则考虑表格的设计。(互联网应用中)表连接方式使用外联优于内联。外连接有基础数据存在。

如:A left join B,基础数据是A。A inner join B,没有基础数据的,先使用笛卡尔积完成全连接,在根据连接条件得到内连接结果集。

大数据量级的表格做分页查询时,如果页码数量过大,则使用子查询配合完成分页逻辑。

Select * from table limit 1000000, 10Select * from table where id in (select pk from table limit100000, 10)

相关文章教程推荐:mysql教程

以上就是SQL语句优化策略介绍的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/365661.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 05:06:56
下一篇 2025年11月6日 05:11:17

相关推荐

  • MySQL事件调度器如何使用_能实现哪些自动化任务?

    mysql事件调度器是内置的定时任务工具,用于自动化周期性操作。一、开启方法:用show variables查看event_scheduler状态,若为off则在配置文件添加event_scheduler=on或临时执行set global开启;二、创建语法:create event定义触发时间、频…

    2025年12月5日 数据库
    000
  • 如何在Laravel中执行数据库迁移

    laravel数据库迁移通过php代码管理数据库结构变更,提供版本控制功能。1. 创建迁移文件:使用artisan命令生成带时间戳的迁移文件并定义up()和down()方法;2. 执行迁移:运行migrate命令按顺序执行未应用的迁移;3. 回滚迁移:使用rollback撤销最近一次迁移,refre…

    2025年12月5日
    000
  • 清理PHPCMS数据库冗余数据的操作步骤

    识别并清理phpcms数据库冗余数据需从历史版本、无效附件、重复统计、缓存、垃圾评论等入手。1.识别冗余:通过查看大表结构定位冗余来源;2.备份数据库:使用mysqldump或系统工具备份;3.清理历史版本:编写sql删除旧版本;4.清理无效附件:用php脚本校验文件存在性后删除;5.合并重复统计:…

    2025年12月5日 后端开发
    000
  • 如何在Laravel中配置数据库索引

    在laravel中配置数据库索引的核心方法是使用迁移系统定义索引以提升查询性能。1. 在创建表时,可在schema::create回调中通过index()、unique()等方法直接添加索引;2. 对已有表,可创建新迁移文件并在schema::table中添加索引;3. laravel支持多种索引类…

    2025年12月5日
    100
  • MySQL如何实现主从复制 MySQL主从复制的配置与常见问题解决

    mysql主从复制的原理是基于二进制日志(binlog),主服务器将数据变更记录到binlog中,从服务器通过i/o线程请求并接收binlog事件,写入中继日志(relay log),再由sql线程读取中继日志并重放,从而实现数据同步;1. 主服务器开启binlog并设置唯一server-id;2.…

    2025年12月5日
    000
  • 如何在Laravel中实现数据补全

    数据补全功能可在用户输入不完整信息时智能猜测并提供完整选项,laravel中可通过前后端协作实现:1.前端使用typeahead.js、select2或awesomplete监听输入框并发送ajax请求;2.后端创建路由和控制器接收输入值,用eloquent orm结合like或全文搜索技术查询数据…

    2025年12月5日
    000
  • 解决PHPMyAdmin操作数据库时的“连接过多”问题

    解决phpmyadmin“连接过多”问题需从配置调整、查询优化和用户行为管理三方面入手。1. 检查当前连接数并调整max_connections参数,根据服务器资源适当增加最大连接数;2. 通过慢查询日志定位耗时sql,使用explain分析执行计划并优化,如添加索引或重写语句;3. 合理设置wai…

    2025年12月5日 后端开发
    000
  • PHPMyAdmin执行SQL语句时结果集显示不全的处理办法

    要解决phpmyadmin执行sql语句结果集显示不全的问题,需调整其配置文件中的两个核心参数:1. 修改$cfg[‘maxrows’]以增加最大显示行数;2. 修改$cfg[‘limitchars’]以增加单元格内容显示长度。此外,还可通过导出数据、…

    2025年12月5日 后端开发
    000
  • MySQL怎样优化SQL语句 MySQL高效SQL语句编写的技巧与规范

    mysql优化sql语句的核心是提升查询速度并减少资源消耗,需通过索引优化、查询结构改进和配置调优等多方面协同实现。1. 索引优化:应根据查询类型选择合适的索引(如b-tree用于范围查询,hash用于等值查询),在where、order by、group by涉及的列上创建索引,优先为高选择性列建…

    2025年12月5日
    000
  • 如何用PHP实现数据分页?高性能分页类设计

    分页在web开发中通过限制查询结果并获取当前页数据实现,php可通过封装分页类兼顾性能与复用性。1. 分页核心是使用sql的limit和offset动态计算偏移量和每页数量;2. 高性能分页应避免大偏移量、缓存总记录数、只查必要字段、利用索引排序;3. 可复用分页类需接收总记录数、当前页码等参数,并…

    2025年12月5日 后端开发
    000
  • 如何优化PHPMyAdmin操作数据库的查询性能

    优化phpmyadmin查询性能的核心在于优化底层数据库和sql语句,而非phpmyadmin本身。1. sql语句精细化:避免select *,仅选取必要字段;确保join条件使用索引,避免在where子句的索引列上使用函数;合理使用like和union all。2. 索引合理构建:在频繁查询的w…

    2025年12月5日 后端开发
    000
  • 解决PHPMyAdmin操作数据库时的死锁问题和预防措施

    死锁发生时,数据库系统会自动回滚一个事务以解除僵局,用户可通过show engine innodb status;诊断死锁原因,并在必要时通过kill命令终止问题进程;根本解决方法包括:1.保持事务短小,减少锁持有时间;2.统一资源访问顺序,避免交叉等待;3.为查询添加合适索引,减少锁定范围;4.使…

    2025年12月5日 后端开发
    000
  • 如何在Laravel中实现数据对比

    在laravel中高效实现数据对比,需明确对比目标并选择合适的数据处理方式。1. 明确数据源:确定对比数据来自数据库、api或配置文件等;2. 数据获取:使用eloquent orm、db facade或http客户端获取数据并转为数组或集合;3. 数据预处理:统一格式和类型,如日期格式化、字符串大…

    2025年12月5日
    000
  • 从连接到插入:PHP操作MySQL全流程

    1.使用mysqli扩展建立与mysql数据库的连接;2.编写sql语句准备操作数据;3.执行sql语句完成数据插入等操作;4.通过预处理语句防止sql注入攻击;5.使用try…catch块处理连接错误;6.通过持久连接、索引、避免select *、批量插入、缓存和优化sql语句提升性能…

    2025年12月5日 后端开发
    300
  • 如何在Laravel中使用软删除恢复

    在laravel中恢复软删除数据的方法主要有两种:对单个模型调用restore()方法,或通过withtrashed()查询后调用restore()批量恢复。1. 恢复单个模型:使用withtrashed()->find()获取软删除记录,再调用restore()将其deleted_at设为n…

    2025年12月5日
    000
  • ThinkPHP的安全机制是什么?ThinkPHP如何防止SQL注入?

    thinkphp通过参数绑定、配置安全措施及输入过滤机制防止sql注入等安全问题。1. 参数绑定:使用where()或bind()方法将数据与sql语句分离,防止恶意代码执行;2. 配置安全:关闭调试模式、验证上传文件、定期更新框架、限制数据库权限、使用https;3. 输入过滤:默认使用htmls…

    2025年12月5日 PHP框架
    000
  • ThinkPHP的性能优化有哪些?ThinkPHP如何提高响应速度?

    1.性能优化需从配置、数据库、缓存、代码、服务器环境五方面入手;2.配置上关闭调试模式、优化路由规则;3.数据库优化包括索引使用、sql精简、避免n+1查询、合理使用orm及分页;4.缓存策略涵盖数据、模板、查询缓存,结合redis/memcached并设计合理失效机制;5.代码层面减少冗余计算、利…

    2025年12月5日 PHP框架
    000
  • ThinkPHP的模型是什么?ThinkPHP如何定义数据模型?

    thinkphp的模型是对数据库表的面向对象抽象,用于简化数据库操作。它通过定义继承自model的类,实现对数据表的映射,支持自动验证、自动完成、关联模型和数据缓存等高级功能。1. 模型分为基础模型、高级模型和空模型三种类型;2. 使用模型时可通过create()和add()方法实现数据验证与插入;…

    2025年12月5日 PHP框架
    000
  • PHP怎么实现数据关联统计 多表关联统计的3种SQL方案

    实现数据关联统计的php方案主要包括使用join语句、子查询和临时表。1. join语句通过连接多表并基于共同字段进行分组统计,适用于直观且逻辑清晰的多表关联;2. 子查询将一个查询结果作为另一个查询的条件,可简化部分复杂查询但可能影响性能;3. 临时表用于存储中间结果,分解复杂查询为多个简单步骤,…

    2025年12月5日 后端开发
    000
  • ThinkPHP的ORM是什么?ThinkPHP如何操作数据库?

    thinkphp的orm通过将数据库表映射为php模型类、数据行映射为对象实例、字段映射为属性,实现用面向对象方式操作数据库,无需手写sql;2. 常用方法包括find()/select()查询、create()/save()新增、update()/inc()/dec()更新、destroy()/d…

    2025年12月5日 PHP框架
    000

发表回复

登录后才能评论
关注微信