- 浏览: 66059 次
- 性别:
- 来自: 重庆
文章分类
最新评论
-
hxtoyou:
Java适配器模式 -
Ueaner:
...
MYSQL查询语句大全集锦 -
volkswageos:
这的管用啊,不过应该指定一下在vs中的设置路径 project ...
运行MFC程序提示没有找到MFC42D.DLL文件的解决方法
1.查询的模糊匹配
尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用.
解决办法:
其实只需要对该脚本略做改进,查询速度便会提高近百倍。改进方法如下:
a、修改前台程序——把查询条件的供应商名称一栏由原来的文本输入改为下拉列表,用户模糊输入供应商名称时,直接在前台就帮忙定位到具体的供应商,这样在调用后台程序时,这列就可以直接用等于来关联了。
b、直接修改后台——根据输入条件,先查出符合条件的供应商,并把相关记录保存在一个临时表里头,然后再用临时表去做复杂关联
2.索引问题
在做性能跟踪分析过程中,经常发现有不少后台程序的性能问题是因为缺少合适索引造成的,有些表甚至一个索引都没有。这种情况往往都是因为在设计表时,没去定义索引,而开发初期,由于表记录很少,索引创建与否,可能对性能没啥影响,开发人员因此也未多加重视。然一旦程序发布到生产环境,随着时间的推移,表记录越来越多
这时缺少索引,对性能的影响便会越来越大了。
这个问题需要数据库设计人员和开发人员共同关注
法则:不要在建立的索引的数据列上进行下列操作:
◆避免对索引字段进行计算操作
◆避免在索引字段上使用not,<>,!=
◆避免在索引列上使用IS NULL和IS NOT NULL
◆避免在索引列上出现数据类型转换
◆避免在索引字段上使用函数
◆避免建立索引的列中使用空值。
3.复杂操作
部分UPDATE、SELECT 语句 写得很复杂(经常嵌套多级子查询)——可以考虑适当拆成几步,先生成一些临时数据表,再进行关联操作
4.update
同一个表的修改在一个过程里出现好几十次,如:
update table1set col1=...where col2=...;update table1set col1=...where col2=.........
象这类脚本其实可以很简单就整合在一个UPDATE语句来完成(前些时候在协助xxx项目做性能问题分析时就发现存在这种情况)
5.在可以使用UNION ALL的语句里,使用了UNION
UNION 因为会将各查询子集的记录做比较,故比起UNION ALL ,通常速度都会慢上许多。一般来说,如果使用UNION ALL能满足要求的话,务必使用UNION ALL。还有一种情况大家可能会忽略掉,就是虽然要求几个子集的并集需要过滤掉重复记录,但由于脚本的特殊性,不可能存在重复记录,这时便应该使用UNION ALL,如xx模块的某个查询程序就曾经存在这种情况,见,由于语句的特殊性,在这个脚本中几个子集的记录绝对不可能重复,故可以改用UNION ALL)
6.在WHERE 语句中,尽量避免对索引字段进行计算操作
这个常识相信绝大部分开发人员都应该知道,但仍有不少人这么使用,我想其中一个最主要的原因可能是为了编写写简单而损害了性能,那就不可取了
9月份在对XX系统做性能分析时发现,有大量的后台程序存在类似用法,如:
......where trunc(create_date)=trunc(:date1)
虽然已对create_date 字段建了索引,但由于加了TRUNC,使得索引无法用上。此处正确的写法应该是
where create_date>=trunc(:date1) and create_date<trunc(:date1)+1< PRE>
或者是
where create_date between trunc(:date1) and trunc(:date1)+1-1/(24*60*60)
注意:因between 的范围是个闭区间(greater than or equal to low value and less than or equal to high value.),
故严格意义上应该再减去一个趋于0的小数,这里暂且设置成减去1秒(1/(24*60*60)),如果不要求这么精确的话,可以略掉这步。
7.对Where 语句的法则
7.1 避免在WHERE子句中使用in,not in,or 或者having。
可以使用 exist 和not exist代替 in和not in。
可以使用表链接代替 exist。Having可以用where代替,如果无法代替可以分两步处理。
例子
SELECT * FROM ORDERS WHERE CUSTOMER_NAME NOT IN (SELECT CUSTOMER_NAME FROM CUSTOMER)
优化 SELECT * FROM ORDERS WHERE CUSTOMER_NAME not exist (SELECT CUSTOMER_NAME FROM CUSTOMER)
7.2 不要以字符格式声明数字,要以数字格式声明字符值。(日期同样)否则会使索引无效,产生全表扫描。
例子使用: SELECT emp.ename, emp.job FROM emp WHERE emp.empno = 7369;不要使用:SELECT emp.ename, emp.job FROM emp WHERE emp.empno = ‘7369’
8.对Select语句的法则
在应用程序、包和过程中限制使用select * from table这种方式。看下面例子
使用SELECT empno,ename,category FROM emp WHERE empno = '7369‘而不要使用SELECT * FROM emp WHERE empno = '7369'
9. 排序
避免使用耗费资源的操作,带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎 执行,耗费资源的排序(SORT)功能. DISTINCT需要一次排序操作, 而其他的至少需要执行两次排序
10.临时表
慎重使用临时表可以极大的提高系统性能
</trunc(:date1)+1<>
尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用.
解决办法:
其实只需要对该脚本略做改进,查询速度便会提高近百倍。改进方法如下:
a、修改前台程序——把查询条件的供应商名称一栏由原来的文本输入改为下拉列表,用户模糊输入供应商名称时,直接在前台就帮忙定位到具体的供应商,这样在调用后台程序时,这列就可以直接用等于来关联了。
b、直接修改后台——根据输入条件,先查出符合条件的供应商,并把相关记录保存在一个临时表里头,然后再用临时表去做复杂关联
2.索引问题
在做性能跟踪分析过程中,经常发现有不少后台程序的性能问题是因为缺少合适索引造成的,有些表甚至一个索引都没有。这种情况往往都是因为在设计表时,没去定义索引,而开发初期,由于表记录很少,索引创建与否,可能对性能没啥影响,开发人员因此也未多加重视。然一旦程序发布到生产环境,随着时间的推移,表记录越来越多
这时缺少索引,对性能的影响便会越来越大了。
这个问题需要数据库设计人员和开发人员共同关注
法则:不要在建立的索引的数据列上进行下列操作:
◆避免对索引字段进行计算操作
◆避免在索引字段上使用not,<>,!=
◆避免在索引列上使用IS NULL和IS NOT NULL
◆避免在索引列上出现数据类型转换
◆避免在索引字段上使用函数
◆避免建立索引的列中使用空值。
3.复杂操作
部分UPDATE、SELECT 语句 写得很复杂(经常嵌套多级子查询)——可以考虑适当拆成几步,先生成一些临时数据表,再进行关联操作
4.update
同一个表的修改在一个过程里出现好几十次,如:
update table1set col1=...where col2=...;update table1set col1=...where col2=.........
象这类脚本其实可以很简单就整合在一个UPDATE语句来完成(前些时候在协助xxx项目做性能问题分析时就发现存在这种情况)
5.在可以使用UNION ALL的语句里,使用了UNION
UNION 因为会将各查询子集的记录做比较,故比起UNION ALL ,通常速度都会慢上许多。一般来说,如果使用UNION ALL能满足要求的话,务必使用UNION ALL。还有一种情况大家可能会忽略掉,就是虽然要求几个子集的并集需要过滤掉重复记录,但由于脚本的特殊性,不可能存在重复记录,这时便应该使用UNION ALL,如xx模块的某个查询程序就曾经存在这种情况,见,由于语句的特殊性,在这个脚本中几个子集的记录绝对不可能重复,故可以改用UNION ALL)
6.在WHERE 语句中,尽量避免对索引字段进行计算操作
这个常识相信绝大部分开发人员都应该知道,但仍有不少人这么使用,我想其中一个最主要的原因可能是为了编写写简单而损害了性能,那就不可取了
9月份在对XX系统做性能分析时发现,有大量的后台程序存在类似用法,如:
......where trunc(create_date)=trunc(:date1)
虽然已对create_date 字段建了索引,但由于加了TRUNC,使得索引无法用上。此处正确的写法应该是
where create_date>=trunc(:date1) and create_date<trunc(:date1)+1< PRE>
或者是
where create_date between trunc(:date1) and trunc(:date1)+1-1/(24*60*60)
注意:因between 的范围是个闭区间(greater than or equal to low value and less than or equal to high value.),
故严格意义上应该再减去一个趋于0的小数,这里暂且设置成减去1秒(1/(24*60*60)),如果不要求这么精确的话,可以略掉这步。
7.对Where 语句的法则
7.1 避免在WHERE子句中使用in,not in,or 或者having。
可以使用 exist 和not exist代替 in和not in。
可以使用表链接代替 exist。Having可以用where代替,如果无法代替可以分两步处理。
例子
SELECT * FROM ORDERS WHERE CUSTOMER_NAME NOT IN (SELECT CUSTOMER_NAME FROM CUSTOMER)
优化 SELECT * FROM ORDERS WHERE CUSTOMER_NAME not exist (SELECT CUSTOMER_NAME FROM CUSTOMER)
7.2 不要以字符格式声明数字,要以数字格式声明字符值。(日期同样)否则会使索引无效,产生全表扫描。
例子使用: SELECT emp.ename, emp.job FROM emp WHERE emp.empno = 7369;不要使用:SELECT emp.ename, emp.job FROM emp WHERE emp.empno = ‘7369’
8.对Select语句的法则
在应用程序、包和过程中限制使用select * from table这种方式。看下面例子
使用SELECT empno,ename,category FROM emp WHERE empno = '7369‘而不要使用SELECT * FROM emp WHERE empno = '7369'
9. 排序
避免使用耗费资源的操作,带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎 执行,耗费资源的排序(SORT)功能. DISTINCT需要一次排序操作, 而其他的至少需要执行两次排序
10.临时表
慎重使用临时表可以极大的提高系统性能
</trunc(:date1)+1<>
发表评论
-
恶心的Oracle的if else if
2011-02-16 14:16 1206恶心的Oracle的if else if... 前段时间写Or ... -
oracle锁表
2010-12-14 16:12 464加锁是为了防止一些操作而进行的,比如说共享锁,可以防止别的 ... -
ORACLE表空间和导入导出
2010-11-05 23:05 1109-- 创建 WEBCQ 表空间 CREATE SMALLFIL ... -
Oracle内连接、外连接、右外连接、全外连接小总结
2010-09-27 21:54 910数据库版本:Oracle 9i 表TESTA,TESTB, ... -
Oracle数据库中如何选择合适的索引类型
2010-09-27 21:31 934索引就好象一本字典的目录。凭借字典的目录,我们可以非常 ... -
免安装Oracle运行pl/sql developer
2010-08-09 13:54 9551, 从http://www.oracle.com/techn ... -
SQL 2005 函数
2010-04-29 17:03 661聚合函数若要汇总一定范围的数值,请使用以下函数: SUM 返回 ... -
sql常用的 高级编程
2010-04-29 16:52 1013T-SQL 高级编程 /*-变量应用-*/ --局部变量以标 ... -
查询所有表中的记录数
2010-04-29 16:51 767create function row_count (@ta ... -
数据库优化查询计划的方法
2010-04-29 16:50 579数据库系统是管理信息 ... -
sql 存储过程导出表的数据
2010-04-29 16:48 591IF OBJECT_ID('spGenInsertSQL',' ... -
SQL Server2005通用分页存储过程
2010-04-29 16:47 575SET ANSI_NULLS ON GO SET QUOTED ... -
给SQL数据库表和字段添加描述信息
2010-04-29 16:46 1314--创建表 create table userin ... -
oracle修改表增加列删除列修改列
2010-04-29 16:45 9161.增加列 ALTER TABLE table_name AD ... -
ORACLE中日期和时间函数
2010-04-29 16:44 694TO_DATE格式 Day: dd number 12 ... -
将一张表的数据复制到另一张表中
2010-04-29 16:41 1908有两种方法: 1、Insert Into tableb_tmp ... -
sql系统数据库
2010-04-29 16:40 573sysaltfiles ... -
日期字符的转换
2010-04-29 16:39 420Select ROUND(TO_NUMBER(to_date( ... -
oracle MD5加密
2010-04-29 16:39 700Create Or Replace Function func ... -
oracle 函数 和 游标的使用列子
2010-04-29 16:38 851Create Or Replace Function T_JC ...
相关推荐
本文将深入探讨高手们在实践中总结的十条SQL性能优化经验。 1. **避免模糊匹配**:使用LIKE '%parm1%'可能导致索引失效,降低查询效率。解决方法可以是改进前端程序,提供下拉列表限制输入范围,或在后台先筛选出...
接下来,文档详细介绍了十条SQL性能优化的关键要素: 1. 确保提供适当的统计信息。这是性能优化的基础,确保数据库优化器能够根据准确的统计信息制定出高效的执行计划。 2. 尽可能推广阶段2和阶段1谓词。即优化...
### SQL使用技巧十条建议 #### 一、使用索引提升查询速度 **索引**是数据库中一种重要的数据结构,其主要目的是为了加速查询过程。当数据库接收到一个查询请求时,它会根据索引来定位数据,从而避免了全表扫描,...
本项目的总体方案是为 Oracle 数据库提供一个完整的日常维护方案,包括数据库性能优化、数据库安全检查、数据备份和恢复、数据库优化等几个方面。 3.1 数据库性能优化 数据库性能优化是 Oracle 数据库日常维护的...
因此,我们需要优化我们的 SQL 语句,以提高查询速度。 例如,我们可以使用以下优化后的 SQL 语句: SELECT * FROM v_history_data INNER JOIN (SELECT fid FROM t_history_data LIMIT 5000000, 10) AS a ON v_...
7. **性能优化**:为了提高性能,避免一次性加载所有数据,应确保只加载当前页的数据。此外,考虑使用存储过程或者参数化查询,以防止SQL注入攻击。 8. **异常处理**:别忘了添加适当的异常处理代码,以确保在出现...
例如,通过查询v$sqltext和v$sql_plan,可以找出执行全表扫描的SQL语句,这些可能是性能优化的目标。 在数据库出现异常时,物理构造和逻辑构造的故障解决方法是必不可少的。物理构造故障可能涉及磁盘错误或硬件故障...
- 查找前十条性能差的SQL:通过监控和分析,优化执行效率低下的SQL语句。 - 获取等待时间最多的系统等待事件:确定导致性能问题的主要系统等待事件。 - 检查运行很久的SQL:监控并优化长时间运行的SQL语句。 - ...
##### 6.3 查找前十条性能差的SQL - **SQL命令**:`SELECT sql_id, sql_text, executions, elapsed_time, cpu_time FROM v$sqlarea ORDER BY elapsed_time DESC LIMIT 10;` - 此命令用于找出执行时间最长的前十个...
综上所述,Oracle数据库的日常维护工作涵盖了从基础状态检查、日志文件监控、对象和资源使用情况监控、备份检查到性能优化以及安全检查等多个层面,需要数据库管理员(DBA)细致地进行管理和调整,确保数据库的稳定...
6.2 查找前十条性能差的sql:分析执行时间较长的SQL语句,优化查询以提升性能。 6.3 等待时间最多的5个系统等待事件的获取:了解系统中最常见的等待事件,对数据库进行相应的优化。 6.4 检查运行很久的SQL:监控...
查找前十条性能差的sql** - 通过查询`v$sql`视图并排序,找出执行效率低下的SQL语句。 - **6.4. 等待时间最多的5个系统等待事件的获取** - 查询`v$system_event`视图来查找最耗费时间的等待事件。 - **6.5. ...
**4.3 查找前十条性能差的sql** - **目的**:优化性能最差的SQL语句,提高整体性能。 - **方法**:使用`DBMS_SQL_MONITOR`包来查找性能最差的SQL语句。 **4.4 等待时间最多的5个系统等待事件的获取** - **目的**...
查找前十条性能差的sql** - **方法**: 使用 `V$SQL_PLAN_STATISTICS_ALL` 视图并结合统计信息来查找性能较差的SQL语句。 **6.4. 等待时间最多的5个系统等待事件的获取** - **方法**: 通过查询 `V$SYSSTAT` 视图...
12. **性能优化**: - 减少内存分配和释放。 - 使用懒加载和缓存。 - 图片压缩和分辨率适配。 - 使用异步操作避免阻塞主线程。 - 利用GCD优化多线程。 13. **JSON解析优化**: - 批量解析:一次加载大量数据...
综上所述,这十条戒律涵盖了从代码风格、框架选择到安全性等多个方面,都是Java开发者在日常工作中应当遵循的重要原则。遵循这些戒律不仅能帮助开发者写出高质量的代码,还能促进团队的合作与项目的成功。
#### 十二、性能优化方法 - **减少不必要的内存分配**:避免频繁创建临时对象。 - **优化算法复杂度**:选择合适的算法和数据结构。 - **使用缓存**:缓存计算结果,减少重复计算。 - **异步加载**:使用多线程或...
在Web开发中,拖拽排序是一项实用的功能,它允许用户通过直观的拖放操作来调整列表中的元素顺序。... 首先,我们要理解拖拽排序的基本逻辑。...记住,良好的代码组织和性能优化对于提高用户体验至关重要。