[MSSQL]自定义提取中文,简体中文,英文,数字函数汇总
2012-04-25 21:46
155 查看
--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.getEn(@S VARCHAR(100)) RETURNS VARCHAR(100) AS BEGIN WHILE PATINDEX('%[^a-z]%',@S) > 0 BEGIN set @S=stuff(@S,patindex('%[^a-z]%',@S),1,'') END RETURN @S END GO --测试 PRINT DBO.getEn('呵呵ABC123ABC') --ABCABC GO --4.提取简体中文 CREATE FUNCTION DBO.getSimplifiedCN(@S NVARCHAR(100)) RETURNS VARCHAR(100) AS BEGIN WHILE PATINDEX('%[^吖-座]%',@S) > 0 SET @S = STUFF(@S,PATINDEX('%[^吖-座]%',@S),1,N'') RETURN @S END GO PRINT DBO.getSimplifiedCN('呵呵ABC123ABC') GO --5.过滤重复字符 CREATE FUNCTION DBO.distinct_str(@S NVARCHAR(100),@SPLIT VARCHAR(50)) RETURNS VARCHAR(100) AS BEGIN IF @S IS NULL RETURN(NULL) DECLARE @NEW VARCHAR(50),@INDEX INT,@TEMP VARCHAR(50) IF LEFT(@S,1)<>@SPLIT SET @S = @SPLIT+@S IF RIGHT(@S,1)<>@SPLIT SET @S = @S+@SPLIT WHILE CHARINDEX(@SPLIT,@S)>0 AND LEN(@S)<>1 BEGIN SET @INDEX = CHARINDEX(@SPLIT,@S) SET @TEMP = LEFT(@S,CHARINDEX(@SPLIT,@S,@INDEX+LEN(@SPLIT))) IF @NEW IS NULL SET @NEW = ISNULL(@NEW,'')+@TEMP ELSE SET @NEW = ISNULL(@NEW,'')+REPLACE(@TEMP,@SPLIT,'')+@SPLIT WHILE CHARINDEX(@TEMP,@S)>0 BEGIN SET @S=STUFF(@S,CHARINDEX(@TEMP,@S)+LEN(@SPLIT),CHARINDEX(@SPLIT,@S,CHARINDEX(@TEMP,@S)+LEN(@SPLIT))-CHARINDEX(@TEMP,@S),'') END END RETURN RIGHT(LEFT(@NEW,LEN(@NEW)-1),LEN(LEFT(@NEW,LEN(@NEW)-1))-1) END GO PRINT DBO.distinct_str('A,A,B,C,C,B,C,',',') --A,B,C --6.过滤重复字符2 CREATE FUNCTION DBO.distinct_str2(@S varchar(8000)) RETURNS VARCHAR(100) AS BEGIN IF @S IS NULL RETURN(NULL) DECLARE @NEW VARCHAR(50),@INDEX INT,@TEMP VARCHAR(50) WHILE LEN(@S)>0 BEGIN SET @NEW=ISNULL(@NEW,'')+LEFT(@S,1) SET @S=REPLACE(@S,LEFT(@S,1),'') END RETURN @NEW END GO print DBO.distinct_str2('AABCCD') --ABCD
相关文章推荐
- [MSSQL]自定义提取中文,简体中文,英文,数字函数汇总
- sqlserver提取中文_提取英文_提取数字(函数)
- sql 自定义函数返回中文,数字,英文
- 生成随机编码 / SQL语句导入导出大全 //金额阿拉伯数字转换为中文的自定义函数
- 在sqlserver中如何从字符串中提取数字,英文,中文,过滤重复字符
- 提取数字、英文、中文、过滤重复字符等SQL函数(含判断字段是否有中文)
- 提取数字、英文、中文、过滤重复字符等SQL函数(含判断字段是否有中文)
- 字符串提取替换后再替换回去 和 函数将数字转换中文数字
- 提取数字、英文、中文、过滤重复字符等SQL函数(含判断字段是否有中文)
- 实验九用自定义的函数void f(char *line)统计和输出字符串中数字字符、英文字符和其他字符的个数。
- SQL函数:字符串中提取数字,英文,中文,过滤重复字符
- sql server 中的金额阿拉伯数字转换为中文的自定义函数
- 提取数字、提取英文、提取中文、过滤重复字符等SQL函数(含判断字段值是否有中文)
- 设计函数,输入为一个字符串,里边包含中文、英文、数字等字符,编码为GBK。中文字符的编码规则假定为:双字节组成,高字节大于0x80,低字节任意。
- SQL SERVER 提取内容中的数字、中文、英文
- SQL函数:字符串中提取数字,英文,中文,过滤重复字符
- SQL提取中文英文及数字
- ms sql server 中的金额阿拉伯数字转换为中文的自定义函数
- unicode下CString提取判断中文。英文字符。及数字
- 一亿亿以下的阿拉伯数字转中文的自定义函数