sql计算字符串中包含中文、英文字符长度

本文介绍了一种在固定长度字符集中计算字符串中英文字符及中文字符长度的方法,并演示了如何利用SQL查询来实现这一功能。此外,还提供了一个示例说明如何计算字符串中数值的长度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在大唐笔试碰到一个问题,如何计算字符串中中文字符的长度,英文字符的长度。

 

下面这个方法仅用在字符集为固定长度的数据库中:

SQL> WITH STR AS (SELECT 'ABCDE中文字符串FG' S FROM DUAL)
2 SELECT
3 LENGTH(S) * 2 - LENGTHB(S) ENG,
4 LENGTHB(S) - LENGTH(S) CHN,
5 LENGTHB(S) * 2 - LENGTH(S) * 2 CHN_B
6 FROM STR;

ENG CHN CHN_B
---------- ---------- ----------
7 5 10

使用类似的方法可以解决一些其他的问题,比如求字符串中数值的长度:

SQL> WITH STR AS (SELECT 'AB12349J;AL20AB' S FROM DUAL)
2 SELECT
3 LENGTH(S) - LENGTH(REPLACE(TRANSLATE(S, '0123456789', '9999999999'), '9')) NUM,
4 LENGTH(REPLACE(TRANSLATE(S, '0123456789', '9999999999'), '9')) NOT_NUM
5 FROM STR;

NUM NOT_NUM
---------- ----------
7 8

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值