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

java面试(3)SQL优化

任何在Order by语句的非索引项或者有计算表达式都将降低查询速度 应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如select id...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。...整合简单,无关联的数据库访问: 如果你有几个简单的数据库查询语句,你可以把它们整合到一个查询中(即使它们之间没有关系) 尽量多使用COMMIT: 只要有可能,在程序中尽量多使用COMMIT, 这样程序的性能得到提高...减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子: SELECT TAB_NAME FROM TABLES WHERE (TAB_NAME,DB_VER) = ( SELECT...TAB_NAME,DB_VER FROM TAB_COLUMNS WHERE VERSION = 604) 使用表的别名(Alias): 当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个

3.2K20

编写高性能SQL

在这些where子句中,即使某些列存在索引,但是由于编写了劣质的SQL,系统在运行该SQL语句时也不能使用该索引,而同样使用全表扫描,这就造成了响应速度之极大降低。  1....IS NULL 与 IS NOT NULL    不能用null作索引,任何包含null值的列都将不会被包含在索引中。即使索引有多列这样之情况下,只要这些列中有一列含有null,该列就会从索引中排除。...也就是说如果某列存在空值,即使对该列建索引也不会提高性能。    任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 ...第二种查询允许Oracle对salary列使用索引,而第一种查询则不能使用索引。  6. IN和EXISTS    有时候会将一列和一系列值相比较。最简单的办法就是在where子句中使用子查询。...这样优化器就不必遍历整个表而仅根据索引就可完成工作(这里假定在where语句中使用的列存在索引)。相对于IN子句来说,EXISTS使用相连子查询,构造起来要比IN子查询困难一些。

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

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

    但是用IN的SQL性能总是比较低的,从Oracle执行的步骤来分析用IN的SQL与不用IN的SQL有以下区别: ORACLE试图将其转换成多个表的连接,如果转换不成功则先执行IN里面的子查询,再查询外层的表记录...不能用null作索引,任何包含null值的列都将不会被包含在索引中。即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。...也就是说如果某列存在空值,即使对该列建索引也不会提高性能。任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。...(24) 用UNION替换OR (适用于索引列) 通常情况下, 用UNION替换WHERE子句中的OR将会起到较好的效果. 对索引列使用OR将造成全表扫描. 注意, 以上规则只针对多个索引列有效....因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.

    5.7K20

    SQL 性能调优

    替换DISTINCT (19) sql语句用大写的;因为oracle总是先解析sql语句,把小写的字母转换成大写的再执行 (20) 在java代码中尽量少用连接符“+”连接字符串!...能够掌握上面的运用函数解决问题的方法在实际工作中是非常有意义的 回到顶部 (14) 使用表的别名(Alias) 当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来,...= D.DEPT_NO); 回到顶部 (19) sql语句用大写的;因为oracle总是先解析sql语句,把小写的字母转换成大写的再执行 回到顶部 (20) 在java代码中尽量少用连接符“+”连接字符串...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 回到顶部 (37) 联接列 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。

    3.2K10

    SQL 性能调优

    ,在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表。...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里 (12) 减少对表的查询 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子:    ...能够掌握上面的运用函数解决问题的方法在实际工作中是非常有意义的 (14) 使用表的别名(Alias) 当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 (37) 联接列 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。

    2.8K60

    SQL优化

    一、SQL语句编写注意问题 下面就某些SQL语句的where子句编写中需要注意的问题作详细介绍。...在这些where子句中,即使某些列存在索引,但是由于编写了劣质的SQL,系统在运行该SQL语句时也不能使用该索引,而同样使用全表扫描,这就造成了响应速度的极大降低。 1....即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。 2....任何在Order by语句的非索引项或者有计算表达式都将降低查询速度 2、应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如select id from...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。

    4.8K20

    Oracle Sql优化

    8.如果索引不是基于函数的,那么当在Where子句中对索引列使用函数时,索引不再起作用。 9.Where子句中避免在索引列上使用计算,否则将导致索引失效而进行全表扫描。...13.Oracle从下到上处理Where子句中多个查询条件,所以表连接语句应写在其他Where条件前,可以过滤掉最大数量记录的条件必须写在Where子句的末尾。...14.Oracle从右到左处理From子句中的表名,所以在From子句中包含多个表的情况下,将记录最少的表放在最后。...16.当在Sql语句中连接多个表时,使用表的别名,并将之作为每列的前缀。这样可以减少解析时间。...NOT NULL; 6.多列索引,但它的第一个列并没有被Where子句引用; Oracle优化器 1.Oracle优化器(Optimizer)是Oracle在执行SQL之前分析语句的工具。

    1.4K30

    这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)

    它确保索引键列中的值是唯一的。 2.聚集索引:聚集索引对表的物理顺序进行重新排序,并根据键值进行搜索。每个表只有一个聚集索引。...一个表可以具有多个非聚集索引。 它不会改变其排序方式,但是会在一个表内创建一个单独的对象,该对象在搜索后指向原始表行。 20.什么是SQL视图? 视图就像逻辑上存储在数据库中的表的子集。...SQL中有哪些运算符? SQL Operator是保留字,主要在SQL语句的WHERE子句中使用,以执行诸如算术运算和比较之类的操作。这些用于在SQL语句中指定条件。 共有三种类型的运算符。...我们可以在DELETE语句中使用WHERE条件,并可以删除所需的行 我们不能在TRUNCATE语句中使用WHERE条件。...SQL中的字符串函数是什么? SQL字符串函数主要用于字符串操作。

    27.1K20

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

    SQL的大小写是不敏感的(引号内的字符串除外),Oracle会将小写的sql语句转换成大写的,其实大小写对sql的效率影响很小的,主要是业务逻辑的复杂和sql的优化。...3.UNION在子查询语句中使用ORDER BY进行排序,但并不代表UNION后的结果集仍然有序,这个在平时的工作中应该遇到过,比如: (SELECT * FROM user u1 ORDER BY u1...5.在不同值较少的字段上不必要建立索引,如性别字段 6.索引列不能参与计算,保持列“干净”。 6.SQL的优化 1.只返回需要的字段,避免SELECT*。...应尽量避免在 WHERE 子句中对字段进行 null 值判断 判断字段是否为空一般是不会应用索引的,因为索引是不索引空值的。不能用null作索引,任何包含null值的列都将不会被包含在索引中。...即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。

    1.5K50

    SQL 性能优化 总结

    SQL 性能优化 总结 (1)选择最有效率的表名顺序(只在基于规则的优化器中有效): ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表...(2) WHERE子句中的连接顺序:SQL Server、 ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他 WHERE条件之前, 那些可以过 滤掉最大数量记录的条件必须写在...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里。 (12)减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询....sql语句用大写的;因为oracle 总是先解析sql 语句,把小写的字母转换成大写的再执行 (20)在java代码中尽量少用连接符“+”连接字符串!...因此你可以插入 1000条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引 列中,所以WHERE子句中对索引列进行空值比较将使 ORACLE 停用该索引.

    1.9K20

    SQL简介

    :对分组后数据进行过滤 select:对于留下的数据进行字段筛选或计算等 order by:排序永远放在最后执行 伪列 oracle独有的pl-sql的内容 rowid 根据数据在硬盘中存储的物理地址计算得来...子查询使用在where中 如某个查询结果为一条记录中一项(一行一列):把子查询结果作为一个值,直接带入主查询 a:select max(Salary)from employee; b:select*...table where lN="king"//可能有多个数据 select * from table where part-id in(上面) 子查询使用from后面 n行n列:将子查询当做表二次查询...) 如选课表:学生号,课程号(两个组合是唯一的) 在一张表中任意一个字段无法表示一行数据时需要多个字段联合标识:成为联合主键约束 联合主键约束,primary key(字段1,字段2) 联合唯一约束,unique...is null可以在num上设置默认值0,确保表中num列没有null值,然后这样查询:select id from t where num=0 应尽量避免在 where 子句中使用!

    2.7K20

    分享:Oracle sql语句优化

    但是用IN的SQL性能总是比较低的,从ORACLE执行的步骤来分析用IN的SQL与不用IN的SQL有以下区别: ORACLE试图将其转换成多个表的连接,如果转换不成功则先执行IN里面的子查询,再查询...因此你可以插入1000 条具有相同键值的记录,当然它们都是空!因为空值不存在于索引列中,所以WHERE 子句中对索引列进行空值比较将使ORACLE 停用该索引....(非oracle中)on、where、having 这三个都可以加条件的子句中,on是最先执行,where 次之,having最后,因为on是先把不符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据...由 此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里 12、减少对表的查询: 在含有子查询的SQL 语句中,要特别注意减少对表的查询.例子: 1 SELECT...能够掌握上面的运用函数解决问题的方法在实际工作中是非常有意义的 使用表的别名(Alias): 当在SQL 语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column 上.这样一来, 就可以减少解析的时间并减少那些由

    3K10

    SQL优化快速入门

    这儿将基于黄德承大神的Oracle SQL语句优化一书,选取其中比较实用和通用的部分进行介绍。 ?...任何SQL语句,只要在where子句中实用了is null或is not null,那么Oracle优化器不会使用索引。...%的like语句中,可以通过like 'c%'使用索引 order by语句,任何在order by语句的非索引项或者有计算表达式都将降低查询速度。...在SQL SERVER中,查看执行计划,发现并没有区别 减少查询的次数(包括对表查询),将多个分离的查询合并 能够在WHERE字句中使用的条件,尽量避免放在HAVING字句中 用...用>=代替> 注意隐式转换 UNION-ALL替换UNION 在严格遵守条件的情况下(所有的列必须包含在相同的索引中并保持在索引中的排列顺序,所有的列必须定义为非空),

    1.4K90

    Oracle面试题

    Oracle中使用 || 这个符号连接字符串 如 ‘abc’ || ‘d’5.Mysql数据库与Oracle 数据库有什么区别?1,Mysql是中小型应用的数据库。一般用于个人和中小型企业。...3,group by 用法:Mysql中group by 在SELECT语句中可以随意使用,但在ORACLE中如果查询语句中有组函数,那么其他列必须是组函数处理过的或者是group by子句中的列,否则会报错...4,引导方面:MySQL中可以用单引号、双引号包起字符串,Oracle中只可以用单引号包起字符串。...和它的优点缺点是什么? 索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。索引可以是唯一的,创建索引允许指定单个列或者是多个列。...(17)避免改变索引列的类型:当比较不同数据类型的数据时, ORACLE自动对列进行简单的类型转换(18)使用表的别名:当在SQL语句中连接多个表时, 尽量使用表的别名并把别名前缀于每个列上。

    1.6K00

    SQL优化法则小记

    由此可见,要想过 滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定,放在那里. 12.减少对表的查询: 在含有子查询的 SQL 语句中,要特别注意减少对表的查询.例子:...能够掌握上面的运用函数解决问题的方法在实际 工作中是非常有意义的 . 14.使用表的别名(Alias): 当在 SQL 语句中连接多个表时, 请使用表的别名并把别名前缀于每个 column 上.这...= d.dept_no); 19.sql 语句用大写的;因为 oracle 总是先解析 sql 语句,把小写的字母转换成大 写的再执行 20.在 java 代码中尽量少用连接符“+”连接字符串!...如果至少有一个列不为空,则记录存在于索引中.举例: 如 果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的 A,B 值为 (123,null) , oracle将不接受下一条具有相同 A,B...因为空值不存在于索引列中,所以 where子句中对索引列进行空值比较将使 oracle停用该索引.

    2.1K90

    数据库相关

    对于数据库的学习包括:sql>过程、触发器等内容,其中重要程度如下: sql>过程、触发器等 oracle数据库: 1、oracle的开发部分,包含两个部分:sql+plsql编程 2、oracle...注意:安装oracle后会出现多个服务,可以设置为手动启动 重要的两个服务为: 1、数据库监听服务,如果要通过远程客户端(如sql develop等)连接数据库,或者直接用程序连接数据库,那么此服务必须打开...、 多字段分组: 既然可以在group by子句中出现多个分组字段,那么在select子句中也可以出现多个字段 范例:要求查询出每个部门的详细信息 包含字段:部门编号、名称、位置、平均工资、总工资...单行多列 多行多列 多行单列 多行多列 子查询出现的地方: 1、where 单行单列 范例:查询出基本工资比allen工资低的员工 范例:查询出基本工资高于公司平均工资的雇员 范例:查找出于...(在统计函数嵌套使用时select字句中不允许出现任何字段,包括分组字段) 3、from 主要功能是确定数据的来源,来源都是数据表(行+列的集合),所以一般都是多行多列子查询 范例:查询出每个部门的编号

    1.9K50

    MySQL 查询专题

    ❑ 大多数SQL实现不允许 GROUP BY 列带有长度可变的数据类型(如文本或备注型字段)。 ❑ 除聚集计算语句外,SELECT 语句中的每一列都必须在 GROUP BY 子句中给出。...where item_price >= 10 ) 列必须匹配 在 WHERE 子句中使用子查询(如这里所示),应该保证SELECT语句具有与 WHERE 子句中相同数目的列。...企图检索多个列将返回错误。 tip: 逐渐增加子查询来建立查询 用子查询测试和调试查询很有技巧性,特别是在这些语句的复杂性不断增加的情况下更是如此。..., where 改成 on select xxx列 from 表A inner join 表b on 条件1=xxx 自然版 sql 的一对一, 多对多关系 子查询 有多个 select 关键字 可以出现的位置...很少见, 看上去像对象 多行多列 select * from 表1 别名1 , (select ... ) 别名2 where 条件 所谓的连接是有针对性的找出关联关系 全文搜索 用基于文本的搜索作为正则表达式匹配列值的更进一步的介绍

    5K30

    MySQL面试题

    3.系统的瓶颈 1).磁盘搜索. 并行搜索,把数据分开存放到多个磁盘中,这样能加快搜索时间. 2).磁盘读写(IO) 可以从多个媒介中并行的读取数据。...在这些where子句中,即使某些列存在索引,但是由于编写了劣质的SQL,系统在运行该SQL语句时也不能使用该索引,而同样使用全表扫描,这就造成了响应速度的极大降低。 1....也就是说如果某列存在空值,即使对该列建索引也不会提高性能。 任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。 2....第二种查询允许Oracle对salary列使用索引,而第一种查询则不能使用索引。 6. IN和EXISTS 有时候会将一列和一系列值相比较。最简单的办法就是在where子句中使用子查询。...在where子句中可以使用两种格式的子查询。

    1.1K20

    Oracle查询性能优化

    原则一:注意WHERE子句中的连接顺序: ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE...这样的条件。 原则二:SELECT子句中避免使用 ‘ * ‘: ORACLE在解析的过程中, 会将'*' 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间 。...当ORACLE”遇到”NOT,他就会停止使用索引转而执行全表扫描. 2、避免在索引列上使用计算. WHERE子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描....因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引....因为子查询的开销是相当昂贵的。具体的例子在后面的案例“一条SQL的优化过程”中。

    2.3K20
    领券