- 浏览: 476959 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (288)
- Java (70)
- Web (11)
- JSP (18)
- JavaScript (25)
- JQuery (22)
- HTML (7)
- CSS (2)
- Struts2.X (6)
- Ibatis/Mybatis (6)
- Hibernate (4)
- Spring (8)
- Oracle (23)
- MySql (9)
- Apache (1)
- Tomcat (9)
- Weblogic (2)
- Maven (6)
- Flex (0)
- Junit (2)
- Test (1)
- SVN (6)
- GIS (3)
- Android (1)
- Eclipse (10)
- Thread (3)
- JVM (1)
- Cache (2)
- Design pattern (1)
- Nosql (3)
- Linux (10)
- Hudson/Jenkins (1)
- MQ (1)
- Network (2)
- 生活工作 (5)
- 架构师之路 (6)
- 知识精华荟萃 (9)
- Interview (13)
最新评论
-
276847139:
方法很有效,我的问题就在是在父项目的.classpa ...
手动添加Maven Dependencies -
coosummer:
推荐使用http://buttoncssgenerator.c ...
button css 样式 -
lqz2012:
DBFFileReader是外部框架里面的吧,不是JDK的。楼 ...
java读取dbf文件 -
xudongcsharp:
lx13345 写道java.lang.NoSuchMetho ...
Spring常用错误 -
lx13345:
jar是hibernate3.3GA,ehcache-1.5. ...
Spring常用错误
1.查询的模糊匹配
尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用.
解决办法:
其实只需要对该脚本略做改进,查询速度便会提高近百倍。改进方法如下:
a、修改前台程序——把查询条件的供应商名称一栏由原来的文本输入改为下拉列表,用户模糊输入供应商名称时,直接在前台就帮忙定位到具体的供应商,这样在调用后台程序时,这列就可以直接用等于来关联了。
b、直接修改后台——根据输入条件,先查出符合条件的供应商,并把相关记录保存在一个临时表里头,然后再用临时表去做复杂关联
2.索引问题
在做性能跟踪分析过程中,经常发现有不少后台程序的性能问题是因为缺少合适索引造成的,有些表甚至一个索引都没有。这种情况往往都是因为在设计表时,没去定义索引,而开发初期,由于表记录很少,索引创建与否,可能对性能没啥影响,开发人员因此也未多加重视。然一旦程序发布到生产环境,随着时间的推移,表记录越来越多
这时缺少索引,对性能的影响便会越来越大了。
这个问题需要数据库设计人员和开发人员共同关注
法则:不要在建立的索引的数据列上进行下列操作:
◆避免对索引字段进行计算操作
◆避免在索引字段上使用not,<>,!=
◆避免在索引列上使用IS NULL和IS NOT NULL
◆避免在索引列上出现数据类型转换
◆避免在索引字段上使用函数
◆避免建立索引的列中使用空值。
3.复杂操作
部分UPDATE、SELECT 语句 写得很复杂(经常嵌套多级子查询)——可以考虑适当拆成几步,先生成一些临时数据表,再进行关联操作
4.update
同一个表的修改在一个过程里出现好几十次,如:
update table1
set col1=...
where col2=...;
update table1
set 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
或者是
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.临时表
慎重使用临时表可以极大的提高系统性能
尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用.
解决办法:
其实只需要对该脚本略做改进,查询速度便会提高近百倍。改进方法如下:
a、修改前台程序——把查询条件的供应商名称一栏由原来的文本输入改为下拉列表,用户模糊输入供应商名称时,直接在前台就帮忙定位到具体的供应商,这样在调用后台程序时,这列就可以直接用等于来关联了。
b、直接修改后台——根据输入条件,先查出符合条件的供应商,并把相关记录保存在一个临时表里头,然后再用临时表去做复杂关联
2.索引问题
在做性能跟踪分析过程中,经常发现有不少后台程序的性能问题是因为缺少合适索引造成的,有些表甚至一个索引都没有。这种情况往往都是因为在设计表时,没去定义索引,而开发初期,由于表记录很少,索引创建与否,可能对性能没啥影响,开发人员因此也未多加重视。然一旦程序发布到生产环境,随着时间的推移,表记录越来越多
这时缺少索引,对性能的影响便会越来越大了。
这个问题需要数据库设计人员和开发人员共同关注
法则:不要在建立的索引的数据列上进行下列操作:
◆避免对索引字段进行计算操作
◆避免在索引字段上使用not,<>,!=
◆避免在索引列上使用IS NULL和IS NOT NULL
◆避免在索引列上出现数据类型转换
◆避免在索引字段上使用函数
◆避免建立索引的列中使用空值。
3.复杂操作
部分UPDATE、SELECT 语句 写得很复杂(经常嵌套多级子查询)——可以考虑适当拆成几步,先生成一些临时数据表,再进行关联操作
4.update
同一个表的修改在一个过程里出现好几十次,如:
update table1
set col1=...
where col2=...;
update table1
set 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
或者是
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.临时表
慎重使用临时表可以极大的提高系统性能
发表评论
-
Mysql linux 命令
2015-07-12 16:07 6751、查看mysql版本 方法一:status; 方法二:se ... -
oracle decode
2015-06-30 11:30 716decode(条件,值1,返回值1, ... -
DDL DML
2014-04-29 13:50 575DDL (Data Definition Language 数 ... -
数据库优化总结
2014-02-28 14:26 749对于一个以数据为中心 ... -
PL/SQL Developer记住登陆密码
2014-01-06 15:22 892在使用PL/SQL Developer时,为了工作方便希 ... -
oracle 命令行导入dmp
2013-12-21 16:44 730导入 imp scott/tiger@ORCL full=y ... -
NLS_LANG is not defined on the client.Character set conversion may cause unexpec
2013-12-21 16:05 2926NLS_LANG is not defined on the ... -
mysql error 1364 Field doesn't have a default values
2013-12-19 17:20 971mysql error 1364 Field doesn't ... -
ORA-01795: maximum number of expressions in a list
2013-11-29 12:55 1063看ORA-01795中给出的内容是SQL语句的 express ... -
如何快速把excel导入oracle
2013-11-14 14:27 901用PLSQL Developer工具。 1 ... -
数据库事务
2013-07-01 15:27 883事务:要么统一完成,要么都不完成 ACID即:事务的原子性、 ... -
数据库索引
2013-07-01 13:18 884一、为什么要创建索引 ... -
oracle10g 配置远程数据库连接(转)
2013-02-20 16:12 855Net Configuration Assistant -&g ... -
解决Oracle ORA-12505, TNS:listener does not currently know of SID given in connect
2012-09-24 13:44 1493完整的错误信息如下: java.sql.SQLExc ... -
oracle 内外连接
2012-08-14 18:37 968select rbm1.id,rbm1.rbm_email,t ... -
oracle中left join和right join的区别
2012-07-05 12:09 1086通俗的讲: A left join ... -
数据库创建索引有什么优点和缺点
2011-11-17 12:33 971数据库中索引的优缺点 为什么要创建索引呢?这是因为,创建索引可 ... -
Oracle中表空间理解
2011-11-15 15:25 960表空间是一个容器,表结构和表里的数据都是在这个表空间里 在一个 ... -
Oracle 数据导入导出
2011-08-06 16:39 1081如果只导出表的结构(建表语句),不导出表的数据,可用Tools ... -
oracle关于日期
2011-08-04 17:41 1007通过jdbc与oracle连接,用rs.getstring(d ...
相关推荐
本文将深入探讨高手们在实践中总结的十条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开发中,拖拽排序是一项实用的功能,它允许用户通过直观的拖放操作来调整列表中的元素顺序。... 首先,我们要理解拖拽排序的基本逻辑。...记住,良好的代码组织和性能优化对于提高用户体验至关重要。