`
yinger_tj
  • 浏览: 9815 次
  • 性别: Icon_minigender_2
  • 来自: 深圳
社区版块
存档分类
最新评论

oracle大小写问题

 
阅读更多
今天装数据库,如下脚本没有生效,查了一下,发现是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密码区分大小写问题

    ### Oracle 11g 密码区分大小写问题详解 #### 一、Oracle 11g 版本特性概述 自 Oracle 11g 版本开始,Oracle 数据库默认开启了密码大小写敏感(case sensitivity)功能。在早期版本如 10g 及其之前的版本中,默认...

    如何:让Oracle表及字段显示为区分大小写

    这种默认的行为使得在大多数情况下,用户无需关心标识符的大小写问题。 #### 如何使Oracle设计的表及其字段显示为区分大小写的形式 为了让Oracle中的表及其字段显示为区分大小写的形式,可以采用以下方法: 1. **...

    Oracle中对像名大小写敏感性的深入解析

    Oracle数据库在默认情况下被广泛认为...在开发和维护Oracle数据库时,应尽量避免使用引号标识对象名,除非有特殊需求,以减少潜在的大小写问题。同时,为了提高代码可读性和一致性,建议始终使用大写字母来编写对象名。

    解决ORALCE大小写限制及登录限制

    1. **统一命名规范**:在创建数据库对象时,始终遵循一种大小写规则,例如全大写或者全小写,这样在查询时就不需要担心大小写问题。 2. **双引号显式定义**:在创建和引用对象时,使用双引号将名称括起来,如`CREATE...

    ORACLE中数据字典大小写问题

    ### ORACLE中数据字典大小写问题 #### 数据字典大小写敏感性 在Oracle数据库中,对于数据字典中的表名和字段名,Oracle实际上处理这些名称时默认是大小写敏感的。这意味着如果创建了一个名为`myTable`的表,并且...

    datax-v202309 oracle reader&writer 区分大小写优化版免费下载

    oracle 默认不区分大小写,优化了datax源码使其区分大小写。 详情参考博客: https://blog.csdn.net/qq_38688267/article/details/140986163 https://blog.csdn.net/qq_38688267/article/details/140986163 ...

    Oracle中金额大小写转换

    总的来说,Oracle中进行金额大小写的转换涉及到对数字字符串的处理、自定义函数的编写以及对汉字数字的映射理解。虽然Oracle本身不直接提供这样的功能,但我们可以通过PL/SQL编程来实现。希望这个示例能帮助你理解并...

    oracle 11g 设置用户密码大小写敏感测试

    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 ...

    oracle11g密码敏感取消

    --去掉字符大小写敏感设置:禁止密码大小写敏感 show parameter sec_case_sensitive_logon alter system set sec_case_sensitive_logon=false ; --Oracle11g中Exp空表的问题:禁用插入数据时才分配空间功能 show ...

    DevExpress DXperience 使用 Linq 及CriteriaOperator 查找 Oracle 字符字段不区分大小写代码

    DevExpress DXperience 使用 Linq 及CriteriaOperator 查找 Oracle 字符字段不区分大小写代码

    Oracle 大小写转换函数实例详解

    在Oracle数据库中,大小写转换是常见的操作,尤其在处理字符串数据时,有时需要将文本统一为大写或小写格式。Oracle提供了几个内置的函数来实现这些转换,本篇文章将详细讲解这些函数的用法,并通过实例进行演示。 ...

    Oracle数据库常见维护问题手册-精典

    ### Oracle数据库常见维护问题手册-精典 #### 数据库基础 **数据库启动方式** Oracle数据库启动通常通过`SQL*Plus`工具来进行。首先确保已经安装并配置了正确的Oracle客户端环境,然后通过以下命令来启动数据库:...

    Oracle性能问题总结

    Oracle 性能问题总结 Oracle 性能问题是数据库管理员和开发者经常遇到的一个棘手问题,本文总结了 Oracle 性能问题的解决方案,涵盖了物理模型优化、索引相关、SQL 相关、表设计和其他几个方面。 在物理模型优化...

    Oracle资料 Oracle九阴真经 Oracle函数大全 Oracle错误码 Oracle参考手册 Oracle全套chm.7z

    例如,`TO_DATE()`用于将字符串转换为日期,`UPPER()`和`LOWER()`用于大小写转换,`SYSDATE`获取当前系统日期等。通过这些函数大全,用户可以快速查找并学习各种函数的用法。 3. **Oracle错误码**:`SQLCodes-...

    oracle常见问题1000个

    ### Oracle常见问题解析 #### 一、Oracle安装后的初始口令 - **Internal**: `internal` - **OracleSys**: `sys/change_on_install` - **System**: `system/manager` - **Scott**: `scott/tiger` - **Sysman**: `...

    Oracle数据库大对象数据存取的两种实现方法及时间性能比较.pdf

    标题中的“Oracle数据库大对象数据存取的两种实现方法及时间性能比较”指的是在Oracle数据库中处理大对象(LOB)数据的两种不同方法,并对比它们的性能。Oracle数据库中的大对象数据通常指的是非结构化的数据,如...

    SQLSERVER导入ORACLE数据库.pdf

    在导入过程中,还需要注意数据库名的大小写问题。如果目的数据库名是小写的 aa,那么在导入 ORACLE 数据库后,数据库名将变为“aa”。如果需要保持数据库名的大小写,可以使用 alter table "table_name" rename to ...

Global site tag (gtag.js) - Google Analytics