91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-08-04 17:37:17 來源:ITPUB博客 閱讀:215 作者:husthxd 欄目:關系型數據庫

本節介紹了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>
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

通州市| 宁夏| 海盐县| 永康市| 扎兰屯市| 铜川市| 秭归县| 黄大仙区| 怀仁县| 西和县| 土默特左旗| 新密市| 长治市| 定日县| 交口县| 乌鲁木齐县| 镇安县| 康乐县| 柘荣县| 玛沁县| 三河市| 个旧市| 新昌县| 托里县| 蓬莱市| 镇江市| 淮滨县| 遂宁市| 汤原县| 兰考县| 疏附县| 大厂| 和政县| 衡阳市| 保山市| 元阳县| 宝坻区| 遂宁市| 松溪县| 林芝县| 中牟县|