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
- MySQL型別轉換注意事項MySql型別
- Oracle的 資料型別比較及注意事項Oracle資料型別
- mysql 配置注意事項、 mysql 資料型別MySQL 資料型別
- 【C++注意事項】1 資料型別及型別轉換C++資料型別
- PostgreSQL:字元——型別及函式SQL字元型別函式
- Oracle使用*的注意事項Oracle
- HTML5面試注意事項HTML面試
- redhat as5 安裝 oracle 10g注意事項RedhatOracle 10g
- 小遊戲引擎選型注意事項遊戲引擎
- 低程式碼開發平臺選型注意事項
- ios開發注意事項iOS
- oracle 轉pg 的注意事項Oracle
- oracle移植到mysql注意事項OracleMySql
- [Android開發] 注意事項Android
- iOS發包前注意事項iOS
- WatchKit 開發注意事項
- Oracle 資料匯出注意事項Oracle
- Oracle臨時表使用注意事項Oracle
- oracle hash join原理及注意事項Oracle
- 複製oracle home的注意事項Oracle
- oracle rac安裝配置注意事項Oracle
- 關於vSphere 5.5硬體版本注意事項
- 低程式碼開發平臺選型的注意事項(下)
- 低程式碼開發平臺選型的注意事項(上)
- 微信小程式開發注意事項微信小程式
- uni-app開發注意事項APP