欢迎光临
我们一直在努力

取得一段汉语的每个字的首字母-.NET教程,评论及其它

建站超值云服务器,限时71元/月

由于一个公司的oa上用到速查编码,必须得到每个字的首字母,便于以后的查询(如:开发部,则为kfb),到网上找到了一些资料,是一个存储过程。

存储过程为:
create  proc log_findcode
@strname nvarchar(20),
@strfindcode nvarchar(20) output
as
begin
declare @word nchar(1),@py nvarchar(4000)
set @py=
while len(@strname)>0
begin
set @word=left(@strname,1)
set @py=@py+(case when unicode(@word) between 19968 and 19968+20901
then (select top 1 py from (
select a as py,n驁 as word
union all select b,n簿
union all select c,n錯
union all select d,n鵽
union all select e,n樲
union all select f,n鰒
union all select g,n腂
union all select h,n夻
union all select j,n攈
union all select k,n穒
union all select l,n鱳
union all select m,n旀
union all select n,n桛
union all select o,n漚
union all select p,n曝
union all select q,n囕
union all select r,n鶸
union all select s,n蜶
union all select t,n籜
union all select w,n鶩
union all select x,n鑂
union all select y,n韻
union all select z,n咗
) t
where word>=@word collate chinese_prc_cs_as_ks_ws
order by py asc) else @word end)
set @strname=right(@strname,len(@strname)-1)
end
set @strfindcode=@py
end

下面是把汉语传入,调用存储过程得到速查编码的方法

public string getpy(string name)//得到速查编码
  {
   sqlcommand cmd=new sqlcommand();
   cmd.commandtype=commandtype.storedprocedure;//类型为存储过程
   cmd.commandtext=”log_findcode”;//已经创建好的存储过程名
   cmd.connection=con;
   con.open();
   sqlparameter parname=new sqlparameter();
   parname.parametername=”@strname”;
   parname.sqldbtype=sqldbtype.nvarchar;
   parname.size=20;
   parname.value=name;

   sqlparameter parmsg=new sqlparameter();
   parmsg.parametername=”@strfindcode”;
   parmsg.direction=parameterdirection.output;
   parmsg.sqldbtype=sqldbtype.nvarchar;
   parmsg.size=50;
   cmd.parameters.add(parname);
   cmd.parameters.add(parmsg);

   cmd.executereader();
   string strfindcode=parmsg.value.tostring();
   con.close();
   return strfindcode;
  }

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 取得一段汉语的每个字的首字母-.NET教程,评论及其它
分享到: 更多 (0)