今天装数据库,如下脚本没有生效,查了一下,发现是oracle数据字段中会把表明字字段等都自动转换成大写,导致在系统表中查不到数据表,删除失败,如下:
BEGIN
DECLARE
cnt integer := 0;
BEGIN
SELECT 1 INTO cnt FROM dual WHERE exists(SELECT * FROM user_tables WHERE table_name = 'NR8120_R_ProtoIF');
IF cnt != 0 THEN
DECLARE
s VARCHAR2(500);
BEGIN
s := 'DROP TABLE NR8120_R_ProtoIF CASCADE CONSTRAINTS';
DBMS_OUTPUT.PUT_LINE(s);
EXECUTE IMMEDIATE s;
END;
END IF;
exception
WHEN no_data_found THEN
DBMS_OUTPUT.PUT_LINE(cnt);
END;
END;
/
CREATE TABLE NR8120_R_ProtoIF
(
MOI VARCHAR2(200) not null
,NEID VARCHAR2(200) not null
,dwIF NUMBER not null
,configureID VARCHAR2(200) not null
);
alter table NR8120_R_ProtoIF
add constraint P_NR8120_R_ProtoIF primary key (MOI,dwIF);
alter table NR8120_R_ProtoIF
add constraint F_NR8120_R_ProtoIF foreign key (configureID)
references NR8120_R_CONFIGURESET (configureID) on delete cascade;
create index IDX_NR8120_R_ProtoIF on NR8120_R_ProtoIF(configureID);
/
--------------------------------------------------------------------------------------------------------------------------------------------------------------------
oracle数据库中字符串转换成大写函数: NLS_UPPER('NR8120_R_ProtoIF');
---------------------------------------------------------------------------------
以下为转载:
在数据库新建一个测试表(数据库版本为ORACLE 10.2.0.1.0),表名为小写的test。 脚本如下所示:
1.CREATE TABLE test
2.(
3. id NUMBER(10),
4. Name VARCHAR2(20),
5. Sex VARCHAR(2)
6.)
7.--查找不到对应数据
8.SELECT * FROM USER_TABLES WHERE TABLE_NAME = 'test'
9.--改用大写才可以查到对应的数据
10.SELECT * FROM USER_TABLES WHERE TABLE_NAME ='TEST'
11.--查找不到对应数据
12.SELECT * FROM ALL_TAB_COLUMNS WHERE TABLE_NAME = 'test';
13.SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME ='TEST';
下面我们用双引号来新建另外一个表(ORACLE 中 " "的作用是强制区分大小写,以及关键字做字段时用"")脚本如下所示:
1.CREATE TABLE "test1"
2.(
3. "id" NUMBER(10),
4. "Name" VARCHAR2(20),
5. "SEX" VARCHAR(2)
6.)
7.SELECT * FROM USER_TABLES WHERE TABLE_NAME = 'test1';
8.SELECT * FROM DBA_TABLES WHERE TABLE_NAME = 'test1';
9.SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME ='test1';
10.SELECT * FROM "test1";
11.--ORA-00942: 表或试图不存在
12.SELECT * FROM test1;
13.--ORA-00904: "NAME": 标识符无效
14.SELECT id, Name, SEX FROM "test1";
15.--ORA-00904: "ID": 标识符无效
16.SELECT id, "Name", SEX FROM "test1";
17.SELECT "id", "Name", SEX FROM "test1";
18.--ORA-00942: 表或试图不存在
19.SELECT "id", "Name", SEX FROM test1;
上面的例子也许会让觉得比较奇怪,这种现象在SQL SERVER里面是不存在的。这是因为ORACLE在建表或者字段时,如果没有双引号,ORACLE会把表名、字段名全部转化为大写字母然后写入数据字典。访问数据字典时,没有双引号ORACLE会将其转化成大写然后再去数据字段中查找。如果加上双引号则能区分大小写。不仅仅关键字不区分大小写,函数名,过程名,表名称,pl/sql块中变量名,用户名,密码等都不区分大小写。
有些人可能不习惯表名、字段全部用大写,而喜欢用小写或大小写混杂的形式,如果是这样的话,你在ORACLE中写脚本时就要注意了,没有处理好,这样会给你带来“无穷的麻烦”
如上所示,你必须在字段上加上"",否则这里报错,哪里起火。而人有时候又是很粗心、健忘的。所以在ORACLE中,还是建议全部用大写,这样可能开始会让你有些不爽,不过习惯了就好了。总比你用""给后面的开发带来很多隐患要好得多。
在ORAClE中,习惯脚本、字段等用大写,有人说能提高效率,这样少了强制转换大写(如果没有双引号的话)开销,也有人说这些开销可以忽略不计,不会有啥性能方面的问题。(当然脚本全部用大写一致,可以避免同一脚本由于大小写问题多次解析,这是可以肯定的)。小弟不才,也不能确定,网上这方面的资料也少,希望大家能讨论
分享到:
相关推荐
oracle11g密码区分大小写问题,自11g开始,oracle缺省区分帐号的密码大小写(case sensitivity), 而11g以下版本则不区分, 在数据字典中以大写形式存在
本文首先讲述了Oracle内部表存储原理,在此基础上如何使Oracle设计的表及其字段显示为区分大小写的形式,最后通过具体例子分析了使用默认全部大写和大小写混写的利弊,同时给出来不同情况在Power Desginer(PD)中的...
一般情况下,使用者在进行Oracle开发或管理里都不会对ORACLE对像名大小写进行区别,因为ORALCE在普通情况下会将所有小写都转换为大写进行处理,所以可以说是大小写不敏感的。但是实际ORACLE内部有它一套完整的对像名...
ORACLE中数据字典大小写问题
在oracle中用psql写的人民币大小写转换
解决ORALCE大小写限制及登录限制解决
DevExpress DXperience 使用 Linq 及CriteriaOperator 查找 Oracle 字符字段不区分大小写代码
主要介绍了Oracle 大小写转换函数实例详解的相关资料,需要的朋友可以参考下
11g通过一个参数设置密码大小写敏感,下面来做个试验: C:\Documents and Settings\guogang>sqlplus gg_test/gg_test@10.10.15.25_gg SQL*Plus: Release 10.2.0.1.0 – Production on 星期一 8月 4 17:54:19 2014 ...
--去掉字符大小写敏感设置:禁止密码大小写敏感 show parameter sec_case_sensitive_logon alter system set sec_case_sensitive_logon=false ; --Oracle11g中Exp空表的问题:禁用插入数据时才分配空间功能 show ...
oracle 金额大小写转换
java(区分大小写):yyyy-MM-dd HH:mm:ss 12小时制: java(区分大小写):yyyy-MM-dd hh:mm:ss 2)毫秒: java: SSS 24小时制: java(区分大小写):yyyy-MM-dd HH:mm:ss.SSS 12小时制: java(区分大...
oracle sql性能优化方案,自己的总结,希望大家提建议
大小写不敏感查询数据库oracle、java大小写不敏感替换
oracle汉字转拼音函数,支持拼音大小写,首字母
人民币小写转大写 人民币小写转大写 人民币小写转大写 人民币小写转大写
2.1 大小写风格 2.2 缩进风格 2.3 空格及换行 2.4 其它 3、命名规范: 3.1 对象命名汇总表 3.2 对象命名 3.3 变量命名 3.4 表分区命名 4、注释规范 5、语法规范 6、脚本规范 7、性能优化 8、设计规范 8.1 ...