zoukankan      html  css  js  c++  java
  • 取得一段汉语的每个字的首字母

     

      由于一个公司的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;
      }

  • 相关阅读:
    POJ 2187 Beauty Contest(凸包+旋转卡壳)
    POJ 3845 Fractal(计算几何の旋转缩放)
    POJ 1755 Triathlon(线性规划の半平面交)
    POJ 2540 Hotter Colder(半平面交)
    POJ 3525/UVA 1396 Most Distant Point from the Sea(二分+半平面交)
    POJ 3348 Cows(凸包+多边形面积)
    POJ 1228 Grandpa's Estate(凸包唯一性判断)
    POJ 2826 An Easy Problem?!(线段交点+简单计算)
    如何在ARC代码中混编非ARC代码
    给view 添加事件
  • 原文地址:https://www.cnblogs.com/baddot/p/238332.html
Copyright © 2011-2022 走看看