SQL查询效率where语句条件

Posted jtlgb

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL查询效率where语句条件相关的知识,希望对你有一定的参考价值。

有索引的列优先,都有索引的看查询出来的数据量,少的优先

in ,not in,<>,is null,is not null 等由于不会走索引,尽量不要使用。

WHERE子句后面的条件顺序对大数据量表的查询会产生直接的影响,如

Select * from zl_yhjbqk where dy_dj = ‘1K以下‘ and xh_bz=1

Select * from zl_yhjbqk where xh_bz=1 and dy_dj = ‘1K以下‘

以上两个SQL中dy_dj及xh_bz两个字段都没进行索引,所以执行的时候都是全表扫描,第一条SQL的dy_dj = ‘1KV以下‘条件在记录集内比率为99%,而xh_bz=1的比率只为0.5%,在进行第一条SQL的时候99%条记录都进行dy_dj及xh_bz的比较,而在进行第二条SQL的时候0.5%条记录都进行dy_dj及xh_bz的比较,以此可以得出第二条SQL的CPU占用率明显比第一条低。










以上是关于SQL查询效率where语句条件的主要内容,如果未能解决你的问题,请参考以下文章

要提高SQL查询效率where语句条件的先后次序应如何写

SQL语句的效率问题

SQL多个条件查询语句

sql语句提高数据库查询效率

sql语句where条件查询

SQL语句where多条件查询怎么写?