- 浏览: 1025395 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (529)
- 服务器 (8)
- jsp (1)
- java (6)
- AIX (1)
- solaris (3)
- linux学习 (53)
- javaScript (2)
- hibernate (1)
- 数据库 (74)
- sql语句 (8)
- oracle 学习 (75)
- oracle 案例 (42)
- oracle 管理 (42)
- Oracle RAC (27)
- oracle data guard (12)
- oracle 参数讲解 (14)
- Oracle 字符集 (8)
- oracle性能调优 (24)
- oracle备份与恢复 (12)
- oracle Tablespace (9)
- oracle性能诊断艺术 (1)
- oracle 11g学习 (5)
- oracle streams (1)
- oracle upgrade and downgrade (4)
- db2学习 (13)
- db2命令学习 (2)
- mysql (28)
- sql server (30)
- sql server 2008 (0)
- 工具 (10)
- 操作系统 (3)
- c++ (1)
- stock (1)
- 生活 (5)
- HADOOP (2)
最新评论
-
massjcy:
...
如何将ubuntu文件夹中文名改为英文 -
skypiea:
谢谢。。。
终于解决了。。。
Oracle 10.2.0.4(5)EM不能启动的解决方案(Patch 8350262) -
qwe_rt:
引用vi /etc/sysconfig/network 请问 ...
Linux操作系统下配置静态IP上网 -
liuqiang:
sudo killall -9 apache2
ps 和 kill 命令详解 -
dazuiba:
引用*绝杀 kill -9 PID 当使用此命令时,一定要通过 ...
ps 和 kill 命令详解
项目已经开发完毕,由于业务变动,某些查询需要忽略大小写,研究是否在不修改原来SQL语句的基础上,通过修改数据库参数满足业务。
实验如下:
SYS@huiche>conn /@huiche as sysdba;
已连接。
假如项目中有一张表 t:
SYS@huiche>create table t (name varchar2(10));
表已创建。
SYS@huiche>insert into t values ('test');
已创建 1 行。
SYS@huiche>insert into t values ('TEST');
已创建 1 行。
SYS@huiche>begin
2 for i in 1..1000 loop
3 insert into t values ('hello');
4 end loop;
5 end;
6 /
PL/SQL 过程已成功完成。
提交完成。
SYS@huiche>begin
2 dbms_stats.gather_table_stats(user,'t');
3 end;
4 /
PL/SQL 过程已成功完成。
SYS@huiche>set autotrace on;
假设业务SQL语句执行如下:
SYS@huiche>select * from t where name like 't%';
NAME
----------------------------------------
test
执行计划
----------------------------------------------------------
Plan hash value: 1601196873
--------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 334 | 1670 | 2 (0)| 00:00:01 |
|* 1 | TABLE ACCESS FULL| T | 334 | 1670 | 2 (0)| 00:00:01 |
--------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter("NAME" LIKE 't%')
统计信息
----------------------------------------------------------
135 recursive calls
0 db block gets
18 consistent gets
0 physical reads
0 redo size
417 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
2 sorts (memory)
0 sorts (disk)
1 rows processed
SYS@huiche>create index t_name_index on t(name);
索引已创建。
创建索引以后走的是索引扫描。
SYS@huiche>select * from t where name like 't%';
NAME
----------------------------------------
test
执行计划
----------------------------------------------------------
Plan hash value: 837813613
---------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
---------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 334 | 1670 | 2 (0)| 00:00:01 |
|* 1 | INDEX RANGE SCAN| T_NAME_INDEX | 334 | 1670 | 2 (0)| 00:00:01 |
---------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - access("NAME" LIKE 't%')
filter("NAME" LIKE 't%')
统计信息
----------------------------------------------------------
1 recursive calls
0 db block gets
2 consistent gets
1 physical reads
0 redo size
417 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
1 rows processed
这张表的另一个业务SQL如下:
SYS@huiche>select * from t where name='test';
NAME
----------------------------------------
test
执行计划
----------------------------------------------------------
Plan hash value: 837813613
---------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
---------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 334 | 1670 | 1 (0)| 00:00:01 |
|* 1 | INDEX RANGE SCAN| T_NAME_INDEX | 334 | 1670 | 1 (0)| 00:00:01 |
---------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - access("NAME"='test')
统计信息
----------------------------------------------------------
1 recursive calls
0 db block gets
2 consistent gets
0 physical reads
0 redo size
417 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
1 rows processed
现在为了忽略大小写,而修改SESSION级别的参数
SYS@huiche>alter session set nls_sort='BINARY_CI';
会话已更改。
SYS@huiche>alter session set nls_comp='LINGUISTIC';
会话已更改。
原来like的查询继续走的索引扫描(不过走的是索引全扫描)
SYS@huiche>select * from t where name like 't%';
NAME
----------------------------------------
TEST
test
执行计划
----------------------------------------------------------
Plan hash value: 3593352198
-------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 334 | 1670 | 2 (0)| 00:00:01 |
|* 1 | INDEX FAST FULL SCAN| T_NAME_INDEX | 334 | 1670 | 2 (0)| 00:00:01 |
-------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter("NAME" LIKE 't%')
统计信息
----------------------------------------------------------
1 recursive calls
0 db block gets
7 consistent gets
2 physical reads
0 redo size
458 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
2 rows processed
原来的等于查询执行计划变成了全表扫描
SYS@huiche>select * from t where name='test';
NAME
----------------------------------------
test
TEST
执行计划
----------------------------------------------------------
Plan hash value: 1601196873
--------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 334 | 1670 | 2 (0)| 00:00:01 |
|* 1 | TABLE ACCESS FULL| T | 334 | 1670 | 2 (0)| 00:00:01 |
--------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter(NLSSORT("NAME",'nls_sort=''BINARY_CI''')=HEXTORAW('7465737
400') )
统计信息
----------------------------------------------------------
1 recursive calls
0 db block gets
5 consistent gets
0 physical reads
0 redo size
458 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
2 rows processed
创建函数索引:
SYS@huiche>create index t_name_function_index on t(NLSSORT("NAME",'nls_sort=''BINARY_CI'''));
索引已创建。
like查询走的还是全索引扫描
SYS@huiche>select * from t where name like 't%';
NAME
----------------------------------------
TEST
test
执行计划
----------------------------------------------------------
Plan hash value: 3593352198
-------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 334 | 1670 | 2 (0)| 00:00:01 |
|* 1 | INDEX FAST FULL SCAN| T_NAME_INDEX | 334 | 1670 | 2 (0)| 00:00:01 |
-------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter("NAME" LIKE 't%')
统计信息
----------------------------------------------------------
8 recursive calls
0 db block gets
9 consistent gets
0 physical reads
0 redo size
458 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
2 rows processed
相等查询走的是INDEX RANGE SCAN 扫描
SYS@huiche>select * from t where name='test';
NAME
----------------------------------------
test
TEST
执行计划
----------------------------------------------------------
Plan hash value: 4037064198
-----------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 10 | 50 | 1 (0)| 00:00:01 |
| 1 | TABLE ACCESS BY INDEX ROWID| T | 10 | 50 | 1 (0)| 00:00:01 |
|* 2 | INDEX RANGE SCAN | T_NAME_FUNCTION_INDEX | 4 | | 1 (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - access(NLSSORT("NAME",'nls_sort=''BINARY_CI''')=HEXTORAW('7465737400') )
统计信息
----------------------------------------------------------
31 recursive calls
0 db block gets
9 consistent gets
1 physical reads
0 redo size
458 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
2 rows processed
假设还有另一张表:业务是SQL语句根据主键查询,实验由于忽略大小写而影响其执行计划:
SYS@huiche>create table test (id number);
表已创建。
SYS@huiche>begin
2 for i in 1..10000 loop
3 insert into test values (i);
4 end loop;
5 end;
6 /
PL/SQL 过程已成功完成。
提交完成。
SYS@huiche>create unique index test_id_index on test(id);
索引已创建。
SYS@huiche>select * from test where id=1;
ID
----------
1
执行计划
----------------------------------------------------------
Plan hash value: 3821046056
-----------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 13 | 1 (0)| 00:00:01 |
|* 1 | INDEX UNIQUE SCAN| TEST_ID_INDEX | 1 | 13 | 1 (0)| 00:00:01 |
-----------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - access("ID"=1)
统计信息
----------------------------------------------------------
1 recursive calls
0 db block gets
2 consistent gets
1 physical reads
0 redo size
413 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
1 rows processed
看来其执行计划没有受到影响。
从以上实验可以看出,设置忽略大小写的参数以后,oracle 将根据语意来进行查询和排序,对有的执行计划是有一定的影响的,通过建立函数索引,可以使查询走向正确的执行计划。
假如在某些业务中又想使用区分大小写的查询怎么办?
可以用函数解决:
例如:
想查询t表中name为test的记录:
SYS@huiche>select * from t where nlssort(name,'nls_sort=''BINARY''')=nlssort('test','nls_sort=''BINARY''');
NAME
------------------------------
test
执行计划
----------------------------------------------------------
Plan hash value: 1601196873
--------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 2 | 14 | 3 (0)| 00:00:01 |
|* 1 | TABLE ACCESS FULL| T | 2 | 14 | 3 (0)| 00:00:01 |
--------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter("NAME"='test')
Note
-----
- dynamic sampling used for this statement
统计信息
----------------------------------------------------------
19 recursive calls
0 db block gets
20 consistent gets
0 physical reads
0 redo size
411 bytes sent via SQL*Net to client
385 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
1 rows processed
SQL>
以上查询,虽然查出结果,但是走的是全表扫描。
或者更好的方式是修改应用,等每次和数据库建立连接的时候动态设置session级别nls_sort和nls_comp的值,这样就解决了忽略大小写与不忽略大小写同时存在的问题。
思考中,未完待续。
请参考:http://dbua.iteye.com/blog/845245
发表评论
-
Oracle enterprise linux 6.0 安装oracle 11g 所需要的包安装
2012-07-22 08:02 7711Linux 版本是Oracle enterprise ... -
Oracle10gR2 中 Oracle Wallet 的初步使用和维护
2011-06-02 01:59 20011) Wallet作用 从Oracle10gR2开始, 通过 ... -
如何手工删除oracle数据库和软件
2011-06-02 00:29 1472一、手工删库和数据库文件有时候,有可能在dbca图形界面中找不 ... -
AIX下设置Oracle10g随机启动,随机关闭的步骤
2011-06-02 00:19 1462假如ORACLE_HOME为/opt/app/oracle/p ... -
数据库突然无法登陆,只有sysdba可以
2011-05-20 18:05 1659数据库突然无法登陆,只有sysdba可以登陆。 检查aler ... -
Linux安装Oracle报Checking operating system version must be redhat-3, SuSE-9, redhat
2011-03-24 01:26 1928在Linux系统中安装oralce的过程中,如果Linux发行 ... -
How To Update NLS_SORT Parameter Value When Using 10g Thin JDBC Driver ? [ID 469
2010-12-17 10:05 2978Applies to: JDBC - Version: 1 ... -
使用SQL_TRACE进行数据库诊断(转自eygle)
2010-12-16 17:30 869SQL_TRACE是Oracle提供的用 ... -
Read By Other Session
2010-12-02 22:52 765Read By Other Session Definiti ... -
必须引起DBA重视的Oracle数据库碎片
2010-12-01 17:35 1023目前,Oracle已经广泛的应用于各个行业。作为一名DBA,及 ... -
Wait Event: cache buffers chains
2010-11-30 15:58 1174cache buffers chains是相对比较常见的冲突事 ... -
log file sync(日志文件同步) 与 Log file parallel write 等待事件
2010-11-28 20:47 2156log file sync(日志文件同步)等待事件具有一个参数 ... -
删除Linux非rac环境下的ASM实例
2010-04-25 01:48 2031环境说明: 操作系统:CentOS 5 x86数据库:O ... -
扩大oracle最大session数以及清除inactive会话
2010-04-12 16:00 7341从上周起,服务器Oracle数据库出现问题,用不到半天,就会报 ... -
设计数据库时需要考虑的问题
2010-03-04 17:34 1548成功的管理系统=50% 的业务+(25%的数据库+25%的程序 ... -
介绍Oracle数据库锁的种类及研究
2009-12-02 09:30 1124本文通过对Oracle数据库锁机制的研究,首先介绍了Oracl ... -
expdp中使用连接字符串和network_link的区别
2009-12-01 11:47 1586expdp属于服务端工具,而exp属于客户端工具,expdp生 ... -
ora10G 使用数据泵(EXPDP和IMPDP)时应该注意的事项
2009-12-01 11:45 1254Oracle Database 10g引入了最新的数据泵(Da ... -
使用Oracle 10g数据泵(EXPDP/IMPDP)
2009-12-01 11:22 2035一、关于数据泵的概述 在Oracle 10 ... -
10g新特性之-expdp与传统exp的速度比较
2009-12-01 11:18 1316测试环境: System Configuration: Su ...
相关推荐
虽然在Oracle中默认采用全部大写的形式可以简化查询过程,但对于那些希望保留标识符原始大小写状态的开发者来说,通过使用PowerDesigner或其他方法来创建表和字段,可以使Oracle中的表及字段显示为区分大小写的形式...
他认为对于SQL的学习是永无止境的,相信每一个查询Oracle数据库的人都需要精通SQL语言,才能写出高效的查询。他参与本书的编写就是为了帮助别人实现这一目标。 目录 封面 -11 封底 -10 扉页 -9 版权 -8 版权声明 -7...
Oracle数据库的密码区分大小写,且长度有限制。如果你忘记了密码,可以使用数据库管理员的特权重置密码。通常,这需要访问数据库的控制文件,使用特定的SQL语句来更改SYS用户的密码。 #### 使用正确的身份验证模式 ...
- **大小写和重音差异处理**:使用 `NLS_COMP` 和 `NLS_SORT` 参数来控制字符串比较时是否忽略大小写和重音差异。 - **获取全球化配置信息**:可以使用 `DBMS_GLOBALIZATION.get_parameter_value()` 函数获取当前的...
### 数据库迁移方案 #### Oracle数据库升级经验总结与迁移指南 在进行Oracle数据库的升级或迁移过程中,确保数据完整性和业务连续性至关重要。本文将基于提供的文件内容,深入解析Oracle数据库迁移过程中的关键...
然而,这种方法在大数据量分页时可能会有性能问题,因为`OFFSET`会扫描并忽略很多不需要的行。为了避免这种情况,可以使用`ROW_NUMBER()`函数结合子查询来提高效率: ```sql SELECT * FROM ( SELECT *, (@rownum:=...
其一、就业面广:全球前100强企业99家都在使用ORACLE相关技术,中国政府机构,大中型企事业单位都能有ORACLE技术的工程师岗位。 其二、技术层次深:如果期望进入IT服务或者产品公司(类似毕博、DELL、IBM等),...
此外,由于RAID 5在写操作时需要进行校验计算,这可能会对数据库的写性能造成负面影响,尤其是当数据块大小较大时。 TEMP表空间通常用于临时对象,如排序和联接操作,它也需要高性能的随机读写。因此,RAID 5的性能...
Oracle 导入导出 DMP 数据库 Oracle 导入导出 DMP 数据库是指使用 Oracle 数据库管理系统提供的导入导出工具,实现数据库的导入和导出。这里我们将详细介绍两种方法:使用客户端 Enterprise Manager Console 和使用...
Oracle9i初始化参数中文说明 Blank_trimming: 说明: 如果值为TRUE, 即使源长度比目标长度 (SQL92 兼容) 更长, 也允许分配数据。 值范围: TRUE | FALSE 默认值: FALSE serializable: 说明: 确定查询是否获取表级...
2. **外部表**:SQL*Loader也可以利用Oracle的外部表功能,将数据文件视为数据库中的虚拟表,从而直接进行查询和加载。 3. **参数文件**:在运行SQL*Loader时,用户可以指定包含各种选项的参数文件,如数据文件的...
Oracle数据库作为当前最为广泛使用的数据库系统之一,在处理海量数据时必须采用一系列优化策略来提升性能和确保系统的稳定性。 首先,数据库的硬件环境优化是至关重要的。这里的硬件环境主要包括CPU、内存、存储...
在Oracle数据库管理中,创建一个新的数据库实例是一项关键任务,尤其对于Linux环境下的Oracle 10g版本。以下是一个详细的步骤指南,介绍了如何在Linux上创建Oracle 10g 2数据库实例。 首先,确保你已经以`oracle`...
进行SQL查询时,通常会用到“upper”函数来忽略大小写,这是因为不同操作系统中,用户输入的用户名和密码可能存在大小写不一致的情况。在编写SQL查询语句时,应确保其能正确匹配到数据库中的记录。 当初始化块设置...
用户可以选择忽略大小写、空格、行尾字符等差异,也可以自定义规则以适应特定的需求。 在界面设计上,ExamDiff提供了两种视图模式:并排视图和合并视图。并排视图将两个文件或目录的差异以左右对照的方式展示,而...
- `grep -i "pattern" filename` - 忽略大小写进行搜索。 8. **find** - 搜索文件系统中的文件。 - `find /path -name "filename"` - 在指定路径下查找名为 filename 的文件。 - `find . -type f -mtime +30` - ...
- **同步问题**:虽然内存映射简化了并发访问的同步,但并不意味着可以完全忽略,特别是在多个进程修改同一文件时,仍需注意适当的同步机制。 - **异常处理**:程序在映射文件后,必须正确地处理异常情况,例如...
### 数据库的导入与导出方法详解 ...此外,随着技术的发展,现在也有更多现代化的工具和技术可以用来实现数据库的备份和迁移,如Oracle GoldenGate、Oracle Data Pump等,它们提供了更高效、更安全的解决方案。