3.用於安裝的空間也大不相同。Mysql安裝後只有152M,而Oracle有3G左右,Oracle使用時占用大量內存空間和其他機器性能。
4.Oracle在Mysql操作上也有壹些差異。
①主鍵
Mysql壹般使用自動增長類型。創建表時只需要指定表的主鍵為自動增量,插入記錄時不需要指定記錄的主鍵值,Mysql會自動增長。Oracle沒有自動增長類型,主鍵壹般使用序列。插入記錄時,只需將序列號的下壹個值輸入到該字段中。只是ORM框架只要是原生主鍵生成策略。
②單引號的處理
在MYSQL中可以用雙引號將字符串括起來,在ORACLE中只有單引號可以將字符串括起來。在插入和修改字符串之前,必須替換單引號:用兩個單引號替換所有出現的單引號。
③翻頁SQL語句的處理。
MYSQL用於翻頁的SQL語句比較簡單。從極限開始,記錄數字。ORACLE對翻頁SQL語句的處理比較復雜。每個結果集只有壹個rownum字段來指示其位置,並且只有ROWNUM不能使用。80
④長字符串的處理
ORACLE對長字符串的處理也有其特殊之處。插入和更新時,可操作的最大字符串長度小於或等於4000個單字節。如果要插入更長的字符串,請考慮對字段使用CLOB類型,並借用ORACLE附帶的DBMS_LOB包。在插入修改後的記錄之前,必須判斷它是否為非空。您應該警告不能為空的字段值和超過長度的字段值,並返回到上壹個操作。
⑤空字符的處理
MYSQL的非空字段也有空內容,ORACLE定義了非空字段,所以不允許空內容。根據MYSQL的NOT NULL定義ORACLE表結構會導致導入數據時出錯。所以導入數據時要判斷空字符。如果是null或空字符,則需要將其更改為空字符串。
⑥字符串的模糊比較
MYSQL使用類似“% string%”、和%”的字段名,ORACLE也可以使用類似“% string%”的字段名,但是這種方法不能使用索引,速度不快。