·首页 ·asp ·.net ·php ·JSP ·CGI ·数据库 ·网页设计 ·网管专栏 ·XML ·工具软件 ·办公软件 ·操作系统 ·程序设计 ·LINUX 
  当前位置: 普克>>计算机教程>>.net>>评论及其它>>取得一段汉语的每个字的首字母
flash视频教学

photoshop专题

asp.net专题

office专题

取得一段汉语的每个字的首字母


评论及其它 发表时间:2006-4-8 字体:  返回
由于一个公司的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;
  }




上一篇:开发手记(七)——实现图标首窗体的启动滞留
下一篇:ComponentOne之WebChart用法

普克创业投资网刊载此文不代表同意其说法或描述,仅为提供更多信息。
在百度中搜索取得一段汉语的每个字的首字母的相关内容]   [在狗狗中搜索取得一段汉语的每个字的首字母的相关内容]
Copyright @ 2006 PUPK.COM 普克创业投资网 版权所有
 建议使用1024*768以达到最好的浏览效果