数据库某字段要保存中文时,怎样确定长度(以Oracle为例)

1.确定存储中文字数在哪个区间

假设我在前端限制最长保存5个汉字。

2.查询该字数在数据库的长度

以5个汉字为例。

-- Oracle语法
SELECT LENGTH('一二三四五') FROM dual; -- 5 单位是字符
SELECT LENGTHB('一二三四五') FROM dual; -- 15 单位是字节

3.建表并指定列长

VARCHAR2(5 CHAR)VARCHAR2(15)均可。

当以VARCHAR2(15)建表时,Oracle默认指定长度单位是字节(不知道这个没关系,建个表测一下也能发现,实际上实操比找文档快多了)

-- 建表测试
CREATE TABLE TEMP(
TMP1 VARCHAR2(5 CHAR),
TMP2 VARCHAR2(5),
TMP3 VARCHAR2(15)
);

INSERT INTO TEMP (TMP1,TMP2,TMP3) VALUES ('一二三四五',NULL,NULL); -- succeed
INSERT INTO TEMP (TMP1,TMP2,TMP3) VALUES (NULL,'一二三四五',NULL); -- ORA-12899: 列 "TEMP"."TMP2" 的值太大 (实际值: 15, 最大值: 5)
INSERT INTO TEMP (TMP1,TMP2,TMP3) VALUES (NULL,NULL,'一二三四五'); -- succeed

测试结果显示,限制存储数据长度时,建表时可以指定字符长度,也可指定字节长度。

关键在于测试一下要存储的数据在数据库的单位,本例为1汉字对应1字符/3字节

参考链接

ORACLE数据库汉字占几个字节问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值