SQL Server 欄位提取拼音首字母

來源:互聯網
上載者:User

目前工作中遇到一個情況,需要將SQL Server中的一個欄位提取拼音的首字母,欄位由漢字、英文、數字以及“-”構成,百度了一堆,找到如下方法,記錄一下,以備後用!

  首先建立一個函數

--產生拼音首碼    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(中文欄位) AS 列別名FROM        表名稱

 

 感謝:Luckeryin

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.