Oracle 11g對依賴的判斷達到欄位級,oracle11g

來源:互聯網
上載者:User

Oracle 11g對依賴的判斷達到欄位級,oracle11g

     在Oracle 10g下,判斷依賴性只達到了對象級,也就是說預存程序訪問的對象一旦發生了變化,那麼Oracle就會將預存程序置為INVALID狀態。所以在為表做了DDL操作後,需要把預存程序重新進行編譯。

       在Oracle 11g下,對依賴的判斷更加細化,判斷到了欄位級。雖然有這麼好的特性,但我還是建議對錶做了DDL操作後,把預存程序再重新編譯一下。

Oracle 10g下:

SQL> select * from v$version;

BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - 64bi
PL/SQL Release 10.2.0.1.0 - Production
CORE    10.2.0.1.0      Production
TNS for 64-bit Windows: Version 10.2.0.1.0 - Production
NLSRTL Version 10.2.0.1.0 - Production
SQL> drop table TEST purge;
SQL> drop PROCEDURE P_TEST;
SQL> CREATE TABLE TEST(ID NUMBER);
SQL> CREATE OR REPLACE PROCEDURE P_TEST AS
      BEGIN
        INSERT INTO TEST (ID) VALUES (100);
      END;
      /
SQL> col OBJECT_NAME format a10;
SQL> col OBJECT_TYPE format a10;
SQL> col STATUS format a10;
SQL> SELECT OBJECT_NAME, OBJECT_TYPE, STATUS FROM USER_OBJECTS WHERE OBJECT_NAME = 'P_TEST';
OBJECT_NAM OBJECT_TYP STATUS
---------- ---------- ----------
P_TEST     PROCEDURE  VALID
SQL> ALTER TABLE TEST ADD (NAME VARCHAR2(30));
SQL> SELECT OBJECT_NAME, OBJECT_TYPE, STATUS FROM USER_OBJECTS WHERE OBJECT_NAME = 'P_TEST';
OBJECT_NAM OBJECT_TYP STATUS
---------- ---------- ----------
P_TEST     PROCEDURE  INVALID

Oracle 11g下:
SQL> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production

SQL> drop table TEST purge;
SQL> drop PROCEDURE P_TEST;
SQL> CREATE TABLE TEST(ID NUMBER);
SQL> CREATE OR REPLACE PROCEDURE P_TEST AS
      BEGIN
        INSERT INTO TEST (ID) VALUES (100);
      END;
      /

SQL> col OBJECT_NAME format a10;
SQL> col OBJECT_TYPE format a10;
SQL> col STATUS format a10;
SQL> SELECT OBJECT_NAME, OBJECT_TYPE, STATUS FROM USER_OBJECTS WHERE OBJECT_NAME = 'P_TEST';
OBJECT_NAM OBJECT_TYP STATUS
---------- ---------- ----------
P_TEST     PROCEDURE  VALID
SQL> ALTER TABLE TEST ADD (NAME VARCHAR2(30));
SQL> SELECT OBJECT_NAME, OBJECT_TYPE, STATUS FROM USER_OBJECTS WHERE OBJECT_NAME = 'P_TEST';
OBJECT_NAM OBJECT_TYP STATUS
---------- ---------- ----------
P_TEST     PROCEDURE  VALID
oracle 11g表欄位問題

ORACLE中都是使用number類型。

int 是為相容sql標準而提供的。

你用就是了。
 
oracle 11g用戶端,用pl/sql開啟時,資料表中的欄位凡是有漢字的位置都被編碼為?了

-- 查詢服務器當前的字元集資訊.
select USERENV('LANGUAGE') L FROM dual;

首先去查詢一下, 資料庫伺服器的 字元集是什麼。

你需要把用戶端的字元集, 設定得與伺服器的字元集一致/相容, 才能處理啊。
 

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.