[MSSQL]自定义提取中文,简体中文,英文,数字函数汇总

本文汇总了在MSSQL中自定义提取中文、简体中文、英文和数字的函数,包括如何处理NULL值和进行相关测试,适用于数据清洗和处理场景。

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

--1.提取中文
create function dbo.getCN
(
	@str as nvarchar(4000)
)
returns nvarchar(4000)
  as
  begin
  declare  @word  nchar(1),@CN nvarchar(4000)
  set @CN=''
  while len(@str)>0
  begin
  set @word=left(@str,1)
  if unicode(@word) between  19968  and  19968+20901
      set @CN=@CN+@word
  set @str=right(@str,len(@str)-1)
  end
  return @CN
  end
PRINT dbo.getCN('ASDKG论坛KDL')
--论坛
PRINT dbo.getCN('ASDKG論壇KDL')
--論壇
PRINT dbo.getCN('ASDKDL')
--空
--2.提取数字
CREATE FUNCTION DBO.getNumber(@S VARCHAR(100))
RETURNS VARCHAR(100)
AS
BEGIN
WHILE PATINDEX('%[^0-9]%',@S) > 0
BEGIN
set @S=stuff(@S,patindex('%[^0-9]%',@S),1,'')
END
RETURN @S
END
GO
--测试 多个条件用逗号隔开 PATINDEX('%[^0-9,*]%',@S) > 0
PRINT dbo.getNumber('呵呵ABC123ABC')
GO
--123
--3.提取英文
CREATE FUNCTION DBO.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

厦门德仔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值