获取中文首拼码函数

 1 Create function   [dbo].[f_GetPy](@str   nvarchar(4000)) 
 2 returns   nvarchar(4000) 
 3 as 
 4 begin 
 5 declare   @strlen   int,@re   nvarchar(4000) 
 6 declare   @t   table(chr   nchar(1)   collate   Chinese_PRC_CI_AS,letter   nchar(1)) 
 7 insert   into   @t(chr,letter) 
 8     select   '', 'A '   union   all   select   '', 'B '   union   all 
 9     select   '', 'C '   union   all   select   '', 'D '   union   all 
10     select   '', 'E '   union   all   select   '', 'F '   union   all 
11     select   '', 'G '   union   all   select   '', 'H '   union   all 
12     select   '', 'J '   union   all   select   '', 'K '   union   all 
13     select   '', 'L '   union   all   select   '', 'M '   union   all 
14     select   '', 'N '   union   all   select   '', 'O '   union   all 
15     select   '', 'P '   union   all   select   '', 'Q '   union   all 
16     select   '', 'R '   union   all   select   '', 'S '   union   all 
17     select   '', 'T '   union   all   select   '', 'W '   union   all 
18     select   '', 'X '   union   all   select   '', 'Y '   union   all 
19     select   '', 'Z ' 
20     select   @strlen=len(@str),@re= ' ' 
21     while   @strlen> 0 
22     begin 
23         select   top   1   @re=letter+@re,@strlen=@strlen-1 
24             from   @t   a   where   chr <=substring(@str,@strlen,1) 
25             order   by   chr   desc 
26         if   @@rowcount=0 
27             select   @re=substring(@str,@strlen,1)+@re,@strlen=@strlen-1 
28     end 
29     return(@re) 
30 end 

效果如下:

转载于:https://www.cnblogs.com/nimin961145/archive/2013/03/18/2965860.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值