加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQLServer——字符长度

发布时间:2020-12-12 13:28:18 所属栏目:MsSql教程 来源:网络整理
导读:要求:过滤数据库中某个字符串 字段 中的单个字母或是数字 开始的时候使用 sql 函数 ?LEN SELECT * FROM TABLE1 WHERELEN(name)1 结果其中的单个汉字也过滤掉了。这个函数返回的是字符串的长度。 于是使用另一个长度函数 DATALENGTH SELECT * FROM TABLE1 WH

要求:过滤数据库中某个字符串 字段 中的单个字母或是数字

开始的时候使用 sql 函数 ?LEN

SELECT * FROM TABLE1 WHERELEN(name)>1

结果其中的单个汉字也过滤掉了。这个函数返回的是字符串的长度。

于是使用另一个长度函数 DATALENGTH

SELECT * FROM TABLE1 WHEREDATALENGTH(name)>1

结果中过滤了单个字母和数字,而汉字单个返回的长度为2,所以没有过滤掉。

?

要求:获得混合字符串中的中文

如果汉字在右边

declare @S varchar(20)

set @S='4B工程师'

--如果你的汉字都在右边

?

selectright(@S,(DATALENGTH(@S)-len(@S)))

/*

工程师

*/

提取中文的函数

--提取中文

IF OBJECT_ID('DBO.CHINA_STR') ISNOT NULL

DROP FUNCTION DBO.CHINA_STR

GO

CREATE FUNCTION DBO.CHINA_STR(@SNVARCHAR(100))

RETURNS VARCHAR(100)

AS

BEGIN

WHILE PATINDEX('%[^吖-座]%',@S) > 0

SET @S = STUFF(@S,PATINDEX('%[^吖-座]%',@S),1,N'')

RETURN @S

END

PRINT DBO.CHINA_STR('呵呵ABC123ABC')

GO

?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读