Oracle vs PostgreSQL,研發注意事項(5)- 字元型別
本節介紹了Oracle和PG在字元型別上面的部分不同點,具體包括資料儲存方式、實際佔用的空間大小以及查詢返回資料的處理方式等。
一、不同點
資料儲存
Oracle
常規定義的長度,單位為Byte,如使用(N char)定義則為字元
如:
-- 以位元組為單位,實際儲存長度為位元組數
create table t1(c1 varchar2(2));
-- 以字元為單位,實際儲存長度與字元&字符集有關
-- 如GBK字符集,漢字字元2個位元組,ASCII碼1個位元組,大小需根據實際的儲存資料而定
create table t2(c1 varchar2(2 char)); -- 以字元為單位
PG
定義的長度,單位為字元
實際儲存長度與字元&字符集有關,如UTF8字符集,漢字3個位元組,ASCII嗎1個位元組,大小需根據實際的儲存資料而定
查詢返回資料
CHAR型別
Oracle返回實際儲存的資料,包括資料庫自動補足的空格;PG返回的資料會去掉後面的空格,不管是資料庫自動補足的還是資料本身存在的空格.
空串
Oracle把空串視為NULL值,PG則不會.
二、測試資料
PG
UTF8字符集
testdb=# create table tbl1(var varchar(2),fixed char(2));
CREATE TABLE
testdb=# insert into tbl1 values('測試','測試');
INSERT 0 1
testdb=# insert into tbl1 values('測1','測1');
INSERT 0 1
testdb=# insert into tbl1 values('測','測');
INSERT 0 1
testdb=# select lpad(var,2,'*'),octet_length(var),lpad(fixed,2,'*'),octet_length(fixed) from tbl1;
lpad | octet_length | lpad | octet_length
------+--------------+------+--------------
測試 | 6 | 測試 | 6
測1 | 4 | 測1 | 4
*測 | 3 | *測 | 4
(3 rows)
testdb=# create table tbl2(var varchar(4),fixed char(4));
CREATE TABLE
testdb=# insert into tbl2 values('測試','測試 ');
INSERT 0 1
testdb=# select lpad(fixed,4,'*'),octet_length(fixed) from tbl2;
lpad | octet_length
--------+--------------
**測試 | 8
(1 row)
Oracle
GBK字符集
TEST-orcl@server4>create table tbl1(var varchar2(2),fixed char(2));
Table created.
TEST-orcl@server4>insert into tbl1 values('測試','測試');
insert into tbl1 values('測試','測試')
*
ERROR at line 1:
ORA-12899: value too large for column "TEST"."TBL1"."VAR" (actual: 4, maximum:
2)
TEST-orcl@server4>insert into tbl1 values('1','1');
1 row created.
TEST-orcl@server4>select lpad(var,2,'*'),lengthb(var),lpad(fixed,2,'*'),lengthb(fixed) from tbl1;
LPAD LENGTHB(VAR) LPAD LENGTHB(FIXED)
---- ------------ ---- --------------
*1 1 1 2
TEST-orcl@server4>create table tbl2(var varchar2(2 char),fixed char(2 char));
Table created.
TEST-orcl@server4>
TEST-orcl@server4>insert into tbl2 values('測試','測試');
1 row created.
TEST-orcl@server4>insert into tbl2 values('1','1');
1 row created.
TEST-orcl@server4>select lpad(var,2,'*'),lengthb(var),lpad(fixed,2,'*'),lengthb(fixed) from tbl2;
LPAD LENGTHB(VAR) LPAD LENGTHB(FIXED)
---- ------------ ---- --------------
測 4 測 4
*1 1 1 2
TEST-orcl@server4>select lpad(var,4,'*'),lengthb(var),lpad(fixed,4,'*'),lengthb(fixed) from tbl2;
LPAD(VAR LENGTHB(VAR) LPAD(FIX LENGTHB(FIXED)
-------- ------------ -------- --------------
測試 4 測試 4
***1 1 **1 2
TEST-orcl@server4>
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/6906/viewspace-2374884/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle vs PostgreSQL,研發注意事項(7)- 型別轉換OracleSQL型別
- Oracle vs PostgreSQL,研發注意事項(10)- PostgreSQL資料型別轉換規則#2OracleSQL資料型別
- Oracle vs PostgreSQL,研發注意事項(11)- PostgreSQL資料型別轉換規則#3OracleSQL資料型別
- Oracle vs PostgreSQL,研發注意事項(9)- PostgreSQL資料型別轉換規則#1OracleSQL資料型別
- Oracle vs PostgreSQL,研發注意事項(6)- 事務處理OracleSQL
- Oracle vs PostgreSQL,研發注意事項(12) - NULL與索引OracleSQLNull索引
- Oracle vs PostgreSQL,研發注意事項(13) - UPDATE語句OracleSQL
- Oracle vs PostgreSQL,研發注意事項(1)-查詢鎖表OracleSQL
- Oracle vs PostgreSQL,研發注意事項(2)-DDL語句與事務OracleSQL
- Oracle vs PostgreSQL,研發注意事項(8)- Oracle資料比較規則OracleSQL
- Oracle vs PostgreSQL,研發注意事項(3)- 事務回滾之UPDATE操作解析OracleSQL
- Oracle vs PostgreSQL,研發注意事項(4)- PageSize對資料儲存的影響OracleSQL
- Oracle使用*的注意事項Oracle
- PostgreSQL:字元——型別及函式SQL字元型別函式
- Oracle 資料匯出注意事項Oracle
- Oracle臨時表使用注意事項Oracle
- Oracle:記憶體設定注意事項Oracle記憶體
- [Android開發] 注意事項Android
- 低程式碼開發平臺選型注意事項
- vs.net 2003水晶報表部署注意事項
- HTML5面試注意事項HTML面試
- 小遊戲引擎選型注意事項遊戲引擎
- 【ASM】Oracle asm刪除磁碟組注意事項ASMOracle
- Oracle vs PostgreSQL DBA(21)- Oracle VPDOracleSQL
- ERP選型準備、方法及注意事項
- 低程式碼開發平臺選型的注意事項(下)
- 低程式碼開發平臺選型的注意事項(上)
- spring cloud開發、部署注意事項SpringCloud
- 介面開發文件及注意事項
- uni-app開發注意事項APP
- RandomAccessFile注意事項randomMac
- @Lombok注意事項Lombok
- Oracle vs PostgreSQL Develop(17) - ARRAYOracleSQLdev
- Oracle vs PostgreSQL Develop(15) - DISTINCT ONOracleSQLdev
- Oracle vs PostgreSQL Develop(18) - BooleanOracleSQLdevBoolean
- OA系統在選型時的注意事項
- 營銷型網站建設的注意事項網站
- 向下轉型的注意事項與instanceof的使用