首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

优化数据库的方法及SQL语句优化的原则

SQL语句优化的原则: ◆1、使用索引来更快地遍历表 缺省情况下建立的索引是非群集索引,但有时它并不是最佳的。在非群集索引下,数据在物理上随机存放在数据页上。...即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 ◆3、IN和EXISTS EXISTS要远比IN的效率高。...如果不产生大量重复值,可以考虑把子句拆开。拆开的子句中应该包含索引。 ◆9、SET SHOWPLAN_ALL ON 查看执行方案。DBCC检查数据库数据完整性。...经验证,SQL Server性能的最大改进得益于逻辑的数据库设计、 索引设计和查询设计方面。反过来说,最大的性能问题常常是由其中这些相同方面中的不足引起的。

1K20

SQL优化

IS NULL 与 IS NOT NULL 任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。...即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。 2....任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。 仔细检查order by语句以找出非索引项或者表达式,它们会降低性能。...任何在Order by语句的非索引项或者有计算表达式都将降低查询速度 2、应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如select id from...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。

4.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    《干货系列》SQL语句-知无不言言无不尽

    5.在不同值较少的字段上不必要建立索引,如性别字段 6.索引列不能参与计算,保持列“干净”。 6.SQL的优化 1.只返回需要的字段,避免SELECT*。...能用UNION ALL 就不要使用UNION UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果,所以有些不会产生重复数据的情况下,尽量使用...应尽量避免在 WHERE 子句中对字段进行 null 值判断 判断字段是否为空一般是不会应用索引的,因为索引是不索引空值的。不能用null作索引,任何包含null值的列都将不会被包含在索引中。...即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的.对于这种情况我们可以使用相同功能的运算符替换掉,比如 a is not null 改为 a>0 或a>’’

    1.5K50

    【09】Spring源码-分析篇-DI源码分析

    会异常对应的检测 protected void afterSingletonCreation(String beanName) { // 如果当前在创建检查中的排除bean名列表中不包含该beanName...= AbstractBeanDefinition.DEPENDENCY_CHECK_NONE); //经过筛选的PropertyDesciptor数组,存放着排除忽略的依赖项或忽略项上的定义的属性...缓存除了可以提高效率以外,还可以保证在并发的情况下,返回的PropertyDesciptor[]永远都是同一份 //从bw提取一组经过筛选的PropertyDesciptor,排除忽略的依赖项或忽略项上的定义的属性.../从bw提取一组经过筛选的PropertyDesciptor,排除忽略的依赖项或忽略项上的定义的属性 filteredPds = filterPropertyDescriptorsForDependencyCheck...= null) { //应用给定的属性值,解决任何在这个bean工厂运行时其他bean的引用。

    1.1K20

    MySQL 的 Full Join 的实现

    完整的外部连接包括联接表中的所有行,无论另一个表是否具有匹配的行。 如果联接表中的行不匹配,则全外连接的结果集将为缺少匹配行的表的每一列设置为 NULL 。对于匹配的行,返回它们关联的结果。...图 2 dept 表 执行下面的 SQL 脚本,输出图 3 的结果。...,这可以提供理想的结果,但并非在所有情况下都正确。...如果 emp 表或者 dept 表存在重复记录,使用这种方式将会移除重复记录。下面我们将通过 UNION ALL 改写这段 SQL,使之完全达到 FULL JOIN 的效果。...由于不需要排序和删除重复项,因此对于大型结果集,这可能会大大提高效率。 结语 在工作中,我们用到 full join 的场景可能比较少。那么在什么时候你会想到使用 full join呢?

    12.2K31

    数据库性能优化之SQL语句优化

    推荐方案:在业务密集的SQL当中尽量不采用IN操作符,用EXISTS 方案代替。 (b) NOT IN操作符 此操作是强列不推荐使用的,因为它不能应用表的索引。...推荐方案:用NOT EXISTS 方案代替 (c) IS NULL 或IS NOT NULL操作(判断字段是否为空) 判断字段是否为空一般是不会应用索引的,因为索引是不索引空值的。...不能用null作索引,任何包含null值的列都将不会被包含在索引中。即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 推荐方案:用其它相同功能的操作运算代替,如:a is not null 改为 a>0 或a>’’等。...Order by语句对要排序的列没有什么特别的限制,也可以将函数加入列中(象联接或者附加等)。任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。

    5.7K20

    SQL 性能调优

    阅读目录 (1)选择最有效率的表名顺序(只在基于规则的优化器中有效) (2)WHERE子句中的连接顺序 (3)SELECT子句中避免使用 ‘ * ‘ (4)减少访问数据库的次数 (5)在SQL*Plus...语句 虽然目前各种关于SQL优化的图形化工具层出不穷,但是写出自己的SQL工具来解决问题始终是一个最好的方法: SELECT  EXECUTIONS , DISK_READS, BUFFER_GETS,...即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 回到顶部 (37) 联接列 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。...Order by语句对要排序的列没有什么特别的限制,也可以将函数加入列中(象联接或者附加等)。任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。

    3.2K10

    MYSQL哪些情况下会忽略索引

    如何检查SQL语句是否用到索引? 使用“EXPLAIN sql语句”进行调试,查看possible_keys或key possible_keys:可能应用的索引 key:实际使用的索引 ?...哪些情况下索引会被忽略 前导LIKE 语句 前导模糊查询不生效 (如 like '%XX'或者like '%XX%') //生效 explain select * from cartoon where...IS NULL 或 IS NOT NULL,判断为空 7. 不能在索引上做任何操作(计算、函数、自动/手动类型转换) MYSQL索引类型 索引类型 1. 普通索引 (index) 2....唯一索引 (unique) 在普通索引的基础上,会进行排除重复值 3. 主键索引 (primary key) 和唯一索引的区别在于一个表里只能有一个主键索引,但是唯一索引可以有多个。 4....为什么不默认采用HASH索引呢? HASH只能用在=和上,所以功能受限,所以默认采用BTREE。

    71610

    MYSQL哪些情况下会忽略索引

    如何检查SQL语句是否用到索引?...使用“EXPLAIN sql语句”进行调试,查看possible_keys或key possible_keys:可能应用的索引 key:实际使用的索引 哪些情况下索引会被忽略 前导LIKE 语句...前导模糊查询不生效 (如 like ‘%XX’或者like ‘%XX%’) //生效 explain select * from cartoon where `name` like '家里来了位道长大人...“between“ 范围条件,可使用 where xx> 1 and xx<3代替 IS NULL 或 IS NOT NULL,判断为空 不能在索引上做任何操作(计算、函数、自动/手动类型转换...唯一索引 (unique) 在普通索引的基础上,会进行排除重复值 3. 主键索引 (primary key) 和唯一索引的区别在于一个表里只能有一个主键索引,但是唯一索引可以有多个。

    44920

    编写高性能SQL

    在多数情况下,Oracle使用索引来更快的遍历表,优化器主要根据定义的索引来提高性能。...IS NULL 与 IS NOT NULL    不能用null作索引,任何包含null值的列都将不会被包含在索引中。即使索引有多列这样之情况下,只要这些列中有一列含有null,该列就会从索引中排除。...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 http://hovertree.com/menu/oracle/ 2. ...任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。    仔细检查order by语句以找出非索引项或者表达式,它们会降低性能。...NOT    我们在查询时经常在where子句使用一些逻辑表达式,如大于、小于、等于以及不等于等等,也可以使用and(与)、or(或)以及not(非)。NOT可用来对任何逻辑运算符号取反。

    2.3K20

    SQL 性能调优

    (1)选择最有效率的表名顺序(只在基于规则的优化器中有效) ORACLE 的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理...语句 虽然目前各种关于SQL优化的图形化工具层出不穷,但是写出自己的SQL工具来解决问题始终是一个最好的方法: SELECT  EXECUTIONS , DISK_READS, BUFFER_GETS...即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 (37) 联接列 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。...Order by语句对要排序的列没有什么特别的限制,也可以将函数加入列中(象联接或者附加等)。任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。

    2.8K60

    如何在Ubuntu 16.04上使用MySQL全文搜索提高搜索效果

    一种是通过结果的相关性分数进行过滤,另一种是使用IN BOOLEAN从结果中排除特定单词并指定搜索项之间的最大距离。 使用相关性分数 结果的相关性得分量化了搜索项的匹配程度,其中0表示根本不相关。...,因为SQL限制了该子句中可包含的内容。...author: Ethan 1 row in set (0.01 sec) 这是有效的,因为减号运算符告诉DMS标记具有相关性分数为0的排除词的任何文档。在此模式下仅显示具有非零相关性分数的结果。...您还可以使用IN BOOLEAN MODE指定搜索项之间的最大距离。该距离用单词测量,重要的是包括搜索项。例如,短语“猫与狗”的距离为3。...以下命令返回结果,其中出现“travel”和“miles”字样,它们之间的字数不超过2个。

    2.4K40

    Mysql性能优化二:索引优化

    数据列中不重复值出现的个数,这个数量越高,维度就越高。 如数据表中存在8行数据a,b ,c,d,a,b,c,d这个表的维度为4。 要为维度高的列创建索引,如性别和年龄,那年龄的维度就高于性别。...在这个结果集里,先排除掉 vc_City 不等于”郑州”的记录,再排除 i_Age 不等于 25 的记录,最后筛选出唯一的符合条件的记录。...这就是下文要说到的前缀索引,因为一般情况下名字的长度不会超过 10,这样会加速索引查询速度,还会减少索引文件的大小,提高 INSERT 的更新速度。...虽然此时有了三个索引,但 MySQL 只能用到其中的那个它认为似乎是最有效率的单列索引,另外两个是用不到的,也就是说还是一个全表扫描的过程。...5 什么样的sql不走索引 要尽量避免这些不走索引的sql SELECT `sname` FROM `stu` WHERE `age`+=;-- 不会使用索引,因为所有索引列参与了计算 SELECT

    64130

    Mysql性能优化二:索引优化

    要为维度高的列创建索引,如性别和年龄,那年龄的维度就高于性别。 性别这样的列不适合创建索引,因为维度过低。 对 where,on,group by,order by 中出现的列使用索引。...在这个结果集里,先排除掉 vc_City 不等于”郑州”的记录,再排除 i_Age 不等于 25 的记录,最后筛选出唯一的符合条件的记录。...这就是下文要说到的前缀索引,因为一般情况下名字的长度不会超过 10,这样会加速索引查询速度,还会减少索引文件的大小,提高 INSERT 的更新速度。...虽然此时有了三个索引,但 MySQL 只能用到其中的那个它认为似乎是最有效率的单列索引,另外两个是用不到的,也就是说还是一个全表扫描的过程。...5 什么样的sql不走索引 要尽量避免这些不走索引的sql SELECT `sname` FROM `stu` WHERE `age`+10=30;-- 不会使用索引,因为所有索引列参与了计算 SELECT

    59020

    程序员硬核“年终大扫除”,清理了数据库 70GB 空间

    ,需要使用 REINDEX 命令来重建索引,来充分利用索引去重复项的优势。...排除空值的部分索引小于5MB,减少了该指标的 99% 以上! 为了确保不需要这些 NULL 值,我们重置了表上的统计信息,等了一段时间后,我们发现索引的使用就像旧索引一样!...变成不包含null的部分索引,可节省约1.3GB。...从索引中排除空值是否总是有好处?NULL和任何其他值一样有意义。如果查询使用了 IS NULL,这些查询可能会受益于索引NULL。 这个方法仅对空值有用?...使用部分索引排除不经常查询或根本不查询的值可能有益于任何值,而不仅仅是空值。NULL通常表示缺少值,我们没有很多查询在搜索空值,因此将它们从索引中排除是有意义的。 你最终如何清除超过20GB的空间呢?

    2.2K10

    MySQL的 where 1=1会不会影响性能?

    如下示例,通过where 1=1来动态拼接有效的 if语句:sql复制代码 SELECT * FROM user WHERE...条件有值的情况下才去生成 where子句,若 AND或 OR前没有有效语句,where元素会将它们去除,也就是说,如果 Mybatis通过标签动态生成的语句为where AND name...为了排除一次查询不具有代表性,我们分别对两条 SQL语句查询 100遍,然后计算平均值:sql复制代码SET PROFILING = 1;DO SLEEP(0.001); -- 确保每次查询之间有足够时间间隔...Constant-Folding OptimizationMySQL的优化器具有一项称为 Constant-Folding Optimization(常量折叠优化)的功能,可以从查询中消除重言式表达式。...在 SQL查询中,重言式表达式是指无论在什么情况下,结果永远为真,它们通常会被优化器识别并优化掉,以提高查询效率。

    15410

    面试官:MySQL中能过滤到null值吗?

    引言 了不起最近在定位一个bug的时候,发现本应该过滤出15355条数据的,但其实只过滤出了12891条数据。 然后我就把sql找出来,根据debug调试的参数取到,一执行,果然结果只有12891。...,主要就是这个sql。...然而,在某些情况下,可以使用其他操作符或条件语句来实现相同的效果,这取决于查询的逻辑和数据的特点。 一句话:视情况而定,没有什么是必要的。 3....为了代码简单使用不等于未考虑字段值为Null的情况带来的影响 在MySQL中使用不等于操作符()会排除掉字段值为 NULL的情况。...因此,使用不等于操作符时,我们需要注意是否希望包含或排除 NULL值,确保查询的准确性,而这一点在数据库设计初期和编码的时候都要去看下这个字段值的范围。 4.

    24810

    javaweb-maven-2-59

    应用案例-传统web工程查询数据库 解决环境问题 在sql中新建一个数据库,然后导入sql文件夹即可,表以及数据自动生成 工程名:maven_day02_1 创建数据库 SET FOREIGN_KEY_CHECKS...使用4.2.8的 第三种:内部排除法,就是在声明中明确表示不使用某个jar包,自然不会导入,就使用其他的了。这种最常用,直接排除掉了,不容易混乱。...排除的时候可以不写版本号,因为版本大声明里已经做过了 ? 排除,4.2的,使用5的 maven工程要导入jar包的坐标,就必须要考虑解决jar包冲突。...当我们要排除某个jar包下依赖包,在配置exclusions标签的时候,内部可以不写版本号。 因为此时依赖包使用的版本和默认和本jar包一样。...-- 插件仓库的id不允许重复,如果重复后边配置会覆盖前边 --> public Public Repositories http

    51120
    领券