自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(14)
  • 资源 (2)
  • 收藏
  • 关注

转载 Dual伪列

   Dual伪列    含义解释: Dual 是 Oracle中的一个实际存在的表,任何用户均可读取,常用在没有目标表的Select中。使用方法:查看当前连接用户SQL> select user from dual;USER------------------------------SYSTEM

2010-01-18 11:23:00 253

转载 Decode()函数使用技巧

Decode()函数使用技巧含义解释: DECODE(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)该函数的含义如下:IF 条件=值1 THEN    RETURN(翻译值1)ELSIF 条件=值2 THEN    RETURN(翻译值2)    ......ELSIF 条件=值n THEN    RETURN(翻译值n)E

2010-01-18 10:47:00 323

转载 Oracle语句优化53个规则详解(12)

49.       优化GROUP BY 提高GROUP BY 语句的效率,可以通过将不需要的记录在GROUP BY 之前过滤掉。下面两个查询返回相同结果但第二个明显就快了许多。    低效:  SELECT JOB , AVG(SAL)     FROM EMP  GROUP by JOB  HAVING JOB = ‘PRESIDENT’  OR JOB = ‘MA

2008-06-15 11:53:00 323

转载 Oracle语句优化53个规则详解(11)

45.       需要当心的WHERE子句 某些SELECT 语句中的WHERE子句不使用索引。 这里有一些例子。     在下面的例子里, ‘!=’ 将不使用索引。 记住, 索引只能告诉你什么存在于表中, 而不能告诉你什么不存在于表中。     不使用索引: SELECT ACCOUNT_NAME  FROM TRANSACTION  WHERE AMOUNT !=0;

2008-06-15 11:37:00 298

转载 Oracle语句优化53个规则详解(10)

42.       使用提示(Hints)    对于表的访问,可以使用两种Hints.  FULL 和 ROWID     FULL hint 告诉ORACLE使用全表扫描的方式访问指定表。     例如: SELECT /*+ FULL(EMP) */ *  FROM EMP  WHERE EMPNO = 7893;     ROWID hint 告诉ORACLE使

2008-06-15 11:20:00 320

转载 Oracle语句优化53个规则详解(9)

39.       总是使用索引的第一个列  如果索引是建立在多个列上, 只有在它的第一个列(leading column)被where子句引用时,优化器才会选择使用该索引。     译者按:这也是一条简单而重要的规则。 见以下实例。     SQL> create table multiindexusage ( inda number , indb number , descr

2008-06-14 11:08:00 275

转载 Oracle语句优化53个规则详解(8)

36.       用UNION替换OR (适用于索引列)    通常情况下,用UNION替换WHERE子句中的OR将会起到较好的效果。对索引列使用OR将造成全表扫描。注意,以上规则只针对多个索引列有效。如果有column没有被索引,查询效率可能会因为你没有选择OR而降低。     在下面的例子中, LOC_ID 和REGION上都建有索引。     高效:  SELECT LOC_I

2008-06-14 11:07:00 280

转载 Oracle语句优化53个规则详解(7)

32.       避免在索引列上使用计算。    WHERE子句中,如果索引列是函数的一部分。优化器将不使用索引而使用全表扫描。     举例: 低效:  SELECT …     FROM DEPT WHERE SAL * 12 > 25000;     高效:  SELECT …     FROM DEPT  WHERE SAL > 25000/12;  

2008-06-14 11:03:00 272

转载 Oracle语句优化53个规则详解(6)

27.       基础表的选择    基础表(Driving Table)是指被最先访问的表(通常以全表扫描的方式被访问)。 根据优化器的不同, SQL语句中基础表的选择是不一样的。     如果你使用的是CBO (COST BASED OPTIMIZER),优化器会检查SQL语句中的每个表的物理大小,索引的状态,然后选用花费最低的执行路径。     如果你用RBO (RULE BA

2008-06-13 08:37:00 262

转载 Oracle语句优化53个规则详解(5)

24.       用EXPLAIN PLAN 分析SQL语句 EXPLAIN PLAN 是一个很好的分析SQL语句的工具,它甚至可以在不执行SQL的情况下分析语句。 通过分析,我们就可以知道ORACLE是怎么样连接表,使用什么方式扫描表(索引扫描或全表扫描)以及使用到的索引名称。     你需要按照从里到外,从上到下的次序解读分析的结果。 EXPLAIN PLAN分析的结果是用缩进的格式排列

2008-06-13 08:36:00 275

转载 Oracle语句优化53个规则详解(4)

Oracle语句优化53个规则详解(4)17.       使用表的别名(Alias)    当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上。这样一来,就可以减少解析的时间并减少那些由Column歧义引起的语法错误。     (译者注: Column歧义指的是由于SQL中不同的表具有相同的Column名,当SQL语句中出现这个Column时,SQL解析器

2008-06-13 08:35:00 293

转载 Oracle语句优化53个规则详解(3)

10.       删除重复记录 最高效的删除重复记录方法 ( 因为使用了ROWID) DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID)                    FROM EMP X                     WHERE X.EMP_NO = E.EMP_NO);  11.      

2008-06-12 14:03:00 277

转载 Oracle语句优化53个规则详解(2)

5.       WHERE子句中的连接顺序。    ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾。     例如:  (低效,执行时间156.3秒) SELECT …  FROM EMP E WHERE SAL > 50000 AND    J

2008-06-12 14:02:00 306

转载 Oracle语句优化53个规则详解(1)

Oracle语句优化53个规则详解(1)Oracle sql 性能优化调整    1. 选用适合的ORACLE优化器         ORACLE的优化器共有3种: a. RULE (基于规则)    b. COST (基于成本)  c. CHOOSE (选择性)     设置缺省的优化器,可以通过对init.ora文件中OPTIMIZER_MODE参数的各种声明,如RUL

2008-06-12 14:00:00 337

Android应用开发详解

初学Android很好的学习资料,内附源码,更容易学习。本书特点是从基础到技术,逐步深入讲解Andriod应用开发,章节最后附带一开发案例。

2012-02-08

j2re-1_4_2_09

java虚拟机j2re-1_4_2_09

2011-01-21

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除