溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Oracle vs PostgreSQL,研發(fā)注意事項(xiàng)(5)- 字符類型

發(fā)布時(shí)間:2020-08-04 17:37:17 來(lái)源:ITPUB博客 閱讀:210 作者:husthxd 欄目:關(guān)系型數(shù)據(jù)庫(kù)

本節(jié)介紹了Oracle和PG在字符類型上面的部分不同點(diǎn),具體包括數(shù)據(jù)存儲(chǔ)方式、實(shí)際占用的空間大小以及查詢返回?cái)?shù)據(jù)的處理方式等。

一、不同點(diǎn)

數(shù)據(jù)存儲(chǔ)
Oracle
常規(guī)定義的長(zhǎng)度,單位為Byte,如使用(N char)定義則為字符
如:
-- 以字節(jié)為單位,實(shí)際存儲(chǔ)長(zhǎng)度為字節(jié)數(shù)
create table t1(c1 varchar2(2));

-- 以字符為單位,實(shí)際存儲(chǔ)長(zhǎng)度與字符&字符集有關(guān)
-- 如GBK字符集,漢字字符2個(gè)字節(jié),ASCII碼1個(gè)字節(jié),大小需根據(jù)實(shí)際的存儲(chǔ)數(shù)據(jù)而定
create table t2(c1 varchar2(2 char)); -- 以字符為單位

PG
定義的長(zhǎng)度,單位為字符
實(shí)際存儲(chǔ)長(zhǎng)度與字符&字符集有關(guān),如UTF8字符集,漢字3個(gè)字節(jié),ASCII嗎1個(gè)字節(jié),大小需根據(jù)實(shí)際的存儲(chǔ)數(shù)據(jù)而定

查詢返回?cái)?shù)據(jù)
CHAR類型
Oracle返回實(shí)際存儲(chǔ)的數(shù)據(jù),包括數(shù)據(jù)庫(kù)自動(dòng)補(bǔ)足的空格;PG返回的數(shù)據(jù)會(huì)去掉后面的空格,不管是數(shù)據(jù)庫(kù)自動(dòng)補(bǔ)足的還是數(shù)據(jù)本身存在的空格.

空串
Oracle把空串視為NULL值,PG則不會(huì).

二、測(cè)試數(shù)據(jù)

PG
UTF8字符集

testdb=# create table tbl1(var varchar(2),fixed char(2));
CREATE TABLE
testdb=# insert into tbl1 values('測(cè)試','測(cè)試');
INSERT 0 1
testdb=# insert into tbl1 values('測(cè)1','測(cè)1');
INSERT 0 1
testdb=# insert into tbl1 values('測(cè)','測(cè)');
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 
------+--------------+------+--------------
 測(cè)試 |            6 | 測(cè)試 |            6
 測(cè)1  |            4 | 測(cè)1  |            4
 *測(cè)  |            3 | *測(cè)  |            4
(3 rows)

testdb=# create table tbl2(var varchar(4),fixed char(4));
CREATE TABLE
testdb=# insert into tbl2 values('測(cè)試','測(cè)試 ');
INSERT 0 1
testdb=# select lpad(fixed,4,'*'),octet_length(fixed) from tbl2;
  lpad  | octet_length 
--------+--------------
 **測(cè)試 |            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('測(cè)試','測(cè)試');
insert into tbl1 values('測(cè)試','測(cè)試')
                        *
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('測(cè)試','測(cè)試');

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)
---- ------------ ---- --------------
測(cè)              4 測(cè)                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)
-------- ------------ -------- --------------
測(cè)試                4 測(cè)試                  4
***1                1 **1                   2

TEST-orcl@server4>
向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI