sql server自动生成拼音码

复制代码
--执行语句生成函数fn_GetPy
create function fn_GetPy(@str nvarchar(4000))
returns nvarchar(4000)
--WITH ENCRYPTION
as
begin
declare @intLen int
declare @strRet nvarchar(4000)
declare @temp nvarchar(100)
set @intLen = len(@str)
set @strRet = ''
while @intLen > 0
begin
set @temp = ''
select @temp = case
when substring(@str,@intLen,1) >= '' then 'Z'
when substring(@str,@intLen,1) >= '' then 'Y'
when substring(@str,@intLen,1) >= '' then 'X'
when substring(@str,@intLen,1) >= '' then 'W'
when substring(@str,@intLen,1) >= '' then 'T'
when substring(@str,@intLen,1) >= '' then 'S'
when substring(@str,@intLen,1) >= '' then 'R'
when substring(@str,@intLen,1) >= '' then 'Q'
when substring(@str,@intLen,1) >= '' then 'P'
when substring(@str,@intLen,1) >= '' then 'O'
when substring(@str,@intLen,1) >= '' then 'N'
when substring(@str,@intLen,1) >= '' then 'M'
when substring(@str,@intLen,1) >= '' then 'L'
when substring(@str,@intLen,1) >= '' then 'K'
when substring(@str,@intLen,1) >= '' then 'J'
when substring(@str,@intLen,1) >= '' then 'H'
when substring(@str,@intLen,1) >= '' then 'G'
when substring(@str,@intLen,1) >= '' then 'F'
when substring(@str,@intLen,1) >= '' then 'E'
when substring(@str,@intLen,1) >= '' then 'D'
when substring(@str,@intLen,1) >= '' then 'C'
when substring(@str,@intLen,1) >= '' then 'B'
when substring(@str,@intLen,1) >= '' then 'A'
else rtrim(ltrim(substring(@str,@intLen,1)))
end
--对于汉字特殊字符,不生成拼音码
if (ascii(@temp)>127) set @temp = ''
--对于英文中小括号,不生成拼音码
if @temp = '(' or @temp = ')' set @temp = ''
select @strRet = @temp + @strRet
set @intLen = @intLen - 1
end
return lower(@strRet)
end
复制代码
--查询生成的拼音码
select dbo.fn_GetPy(name) from t_role_back
--修改表中pym字段为生成的拼音码
update t_role_back set pym = dbo.fn_GetPy(name)

 

posted @   一隅桥畔  阅读(69)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示