Oracle vs PostgreSQL,研發注意事項(5)- 字元型別

husthxd發表於2018-08-29

本節介紹了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/,如需轉載,請註明出處,否則將追究法律責任。

相關文章