天天看點

程式從MYSQL遷移ORACLE注意事項之一

1. 自動增長的資料類型處理

  MYSQL有自動增長的資料類型,插入記錄時不用操作此字段,會自動獲得資料值。ORACLE沒有自動增長的資料類型,需要建立一個自動增長的序列号,插入記錄時要把序列号的下一個值賦于此字段。

  CREATE SEQUENCE 序列号的名稱 (最好是表名+序列号标記) INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;

  其中最大的值按字段的長度來定, 如果定義的自動增長的序列号 NUMBER(6) , 最大值為999999

  INSERT 語句插入這個字段值為: 序列号的名稱.NEXTVAL

  2. 單引号的處理

  MYSQL裡可以用雙引号包起字元串,ORACLE裡隻可以用單引号包起字元串。在插入和修改字元串前必須做單引号的替換:把所有出現的一個單引号替換成兩個單引号。

  3. 翻頁的SQL語句的處理

  MYSQL處理翻頁的SQL語句比較簡單,用LIMIT 開始位置, 記錄個數;PHP裡還可以用SEEK定位到結果集的位置。ORACLE處理翻頁的SQL語句就比較繁瑣了。每個結果集隻有一個ROWNUM字段标明它的位 置, 并且隻能用ROWNUM<100, 不能用ROWNUM>80。

  以下是經過分析後較好的兩種ORACLE翻頁SQL語句( ID是唯一關鍵字的字段名 ):

  語句一:

  SELECT ID, [FIELD_NAME,...] FROM TABLE_NAME WHERE ID IN ( SELECT ID FROM (SELECT ROWNUM AS NUMROW, ID FROM TABLE_NAME WHERE 條件1 ORDER BY 條件2) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 條件3;

  語句二:

  SELECT * FROM (( SELECT ROWNUM AS NUMROW, c.* from (select [FIELD_NAME,...] FROM TABLE_NAME WHERE 條件1 ORDER BY 條件2) c) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 條件3;