避免使用Oracle的char型別
儘量避免使用Oracle的char型別,即使只有一個位元組,也應該使用varchar2型別。
char的缺點主要有兩個
1.佔用空間大
如果宣告一個char(10)的欄位,僅僅使用了一個位元組,剩餘的9個位元組也會使用空格補齊。
2.在JAVA程式中造成隱患
在下面最常用的JDBC中,查詢一個char型別的欄位,卻查不到任何結果.
主要是因為char型別的欄位,使用空格填充。
所以正確的查詢語句應該是:
select id from a where trim(id)=?
或者
select id from a where id=rpad(?,10)
即使使用了這兩個正確的SQL,也會帶來效能問題。
因為第一個SQL不會利用正常建立的索引,而且在複雜的查詢下,更容易出錯。
所以還是忘了Oracle有char這個型別吧。
char的缺點主要有兩個
1.佔用空間大
如果宣告一個char(10)的欄位,僅僅使用了一個位元組,剩餘的9個位元組也會使用空格補齊。
-
create table a
-
(
-
id char(10)
-
);
-
-
create table b
-
(
-
id varchar2(10)
-
);
-
-
insert into a values('test');
-
insert into b values('test');
- commit;
2.在JAVA程式中造成隱患
在下面最常用的JDBC中,查詢一個char型別的欄位,卻查不到任何結果.
-
public class Test {
-
public static void main(String[] args) throws ClassNotFoundException, SQLException {
-
Class.forName("oracle.jdbc.OracleDriver");
-
Connection connection = DriverManager.getConnection("jdbc:oracle:thin:127.0.0.1:1521:orcl", "edmond", "edmond");
-
PreparedStatement ps = connection.prepareStatement("select id from a where id=?");
-
ps.setString(1, "test");
-
ResultSet result = ps.executeQuery();
-
if (result.next()) {
-
System.out.println(result.getString(1));
-
} else {
-
System.out.println("沒有任何記錄");
-
}
-
result.close();
-
ps.close();
-
connection.close();
-
}
- }
所以正確的查詢語句應該是:
select id from a where trim(id)=?
或者
select id from a where id=rpad(?,10)
即使使用了這兩個正確的SQL,也會帶來效能問題。
因為第一個SQL不會利用正常建立的索引,而且在複雜的查詢下,更容易出錯。
所以還是忘了Oracle有char這個型別吧。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29254281/viewspace-1073337/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 應用中避免使用char/nchar型別型別
- 聊聊Oracle 11g中的char型別使用Oracle型別
- Oracle CHAR,VARCHAR,VARCHAR2,nvarchar型別的區別與使用Oracle型別
- 【基礎】Oracle CHAR,VARCHAR,VARCHAR2,nvarchar型別的區別與使用Oracle型別
- Oracle的資料型別:char/varchar2Oracle資料型別
- const char* 型別不能用於初始化char* 型別實體型別
- char型別的數值轉換型別
- 【C++】CONST CHAR*型別的值不能用於初始化CHAR*型別的實體C++型別
- NTMySQL中varchar和char型別的區別heeMySql型別
- PL/SQL中char型別的暗門SQL型別
- Oracle 資料型別CHAR, NCHAR, VARCHAR2, NVARCHAR2Oracle資料型別
- E0144 "const char *" 型別的值不能用於初始化 "char *" 型別的實體型別
- MySQL字元資料型別char與varchar的區別MySql字元資料型別
- ABAP中Char型別資料轉換成Decimal型別型別Decimal
- oracle to_char函式的使用Oracle函式
- "LPWSTR" 型別的值不能用於初始化 "char *" 型別的實體型別
- oracle的timestamp型別使用Oracle型別
- Oracle型別的建立及使用Oracle型別
- C# - char型別的一些介紹C#型別
- MySQL資料型別操作(char與varchar)MySql資料型別
- 【VS2019 C++】"const char *" 型別的值不能用於初始化 "char *" 型別的實體C++型別
- char str[]和char *str的區別
- 避免資料型別轉換資料型別
- VS中”LPTSTR" 型別的值不能用於初始化 "char *" 型別的實體型別
- 【筆記】VS2017中出現 "const char *" 型別的值不能用於初始化 "char *" 型別的實體筆記型別
- oracle中char與varchar2的區別Oracle
- const char*, char const*, char*const的區別
- Java char 型別究竟佔幾個位元組?Java型別
- MySQL CHAR和VARCHAR資料型別介紹MySql資料型別
- oracle集合型別使用的實驗.TXTOracle型別
- MySQL中資料型別(char(n)、varchar(n)、nchar(n)、nvarchar(n)的區別)MySql資料型別
- std::cout 輸出 unsigned char型別資料型別
- Oracle中date型別使用注意Oracle型別
- ORACLE TO_CHAR()函式中日期格式的使用Oracle函式
- 使用不含萬用字元的like運算子遇到char型別的欄位時要注意!字元型別
- CString與LPCWSTR、LPSTR、char*、LPWSTR等型別的轉換型別
- C++中出現《E0144 "const char *" 型別的值不能用於初始化 "char *" 型別的實體》的錯誤解決方法C++型別
- Python工作筆記-往dll中傳入char*型別的引數並且如何接收char*的值Python筆記型別