sql中根据汉字的拼音首字母查询的函数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql中根据汉字的拼音首字母查询的函数相关的知识,希望对你有一定的参考价值。

/****** Object:  UserDefinedFunction [dbo].[f_GetPy]    Script Date: 06/09/2010 10:31:33 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
create function   [dbo].[f_GetPy](@str   nvarchar(4000)) 
returns   nvarchar(4000) 
as 
begin 
declare   @strlen   int,@re   nvarchar(4000) 
declare   @t   table(chr   nchar(1)   collate   Chinese_PRC_CI_AS,letter   nchar(1)) 
insert   into   @t(chr,letter) 
    select   ‘吖 ‘, ‘A ‘   union   all   select   ‘八 ‘, ‘B ‘   union   all 
    select   ‘嚓 ‘, ‘C ‘   union   all   select   ‘咑 ‘, ‘D ‘   union   all 
    select   ‘妸 ‘, ‘E ‘   union   all   select   ‘发 ‘, ‘F ‘   union   all 
    select   ‘旮 ‘, ‘G ‘   union   all   select   ‘铪 ‘, ‘H ‘   union   all 
    select   ‘丌 ‘, ‘J ‘   union   all   select   ‘咔 ‘, ‘K ‘   union   all 
    select   ‘垃 ‘, ‘L ‘   union   all   select   ‘嘸 ‘, ‘M ‘   union   all 
    select   ‘拏 ‘, ‘N ‘   union   all   select   ‘噢 ‘, ‘O ‘   union   all 
    select   ‘妑 ‘, ‘P ‘   union   all   select   ‘七 ‘, ‘Q ‘   union   all 
    select   ‘呥 ‘, ‘R ‘   union   all   select   ‘仨 ‘, ‘S ‘   union   all 
    select   ‘他 ‘, ‘T ‘   union   all   select   ‘屲 ‘, ‘W ‘   union   all 
    select   ‘夕 ‘, ‘X ‘   union   all   select   ‘丫 ‘, ‘Y ‘   union   all 
    select   ‘帀 ‘, ‘Z ‘ 
    select   @strlen=len(@str),@re= ‘ ‘ 
    while   @strlen> 0 
    begin 
        select   top   1   @[email protected],@[email protected] 
            from   @t   a   where   chr <=substring(@str,@strlen,1) 
            order   by   chr   desc 
        if   @@rowcount=0 
            select   @re=substring(@str,@strlen,1)[email protected],@[email protected] 
    end 
    return(@re) 
end

 

---测试数据---
if object_id(‘[pactinfo]‘) is not null drop table [pactinfo]
go
create table [pactinfo]([ID] int,[pactname] varchar(4))
insert [pactinfo]
select 1,‘正常‘ union all
select 2,‘中国‘ union all
select 3,‘做饭‘ union all
select 4,‘加发‘

---查询---
select 
  * 
from 
  [pactinfo]
where
  dbo.f_GetPy(pactname) like ‘Z%‘

---结果---
ID          pactname 
----------- -------- 
1           正常
2           中国
3 做饭

(所影响的行数为 3 行)

 

以上是关于sql中根据汉字的拼音首字母查询的函数的主要内容,如果未能解决你的问题,请参考以下文章

SQL 获取名字拼音

汉字拼音首字母查询 Sql Function

java+mysql,关于根据拼音首字母查询

java怎么根据汉字获取字的拼音首字母

java获取汉字拼音首字母 --转载

将汉字转换为拼音截取拼音首字母根据字母排序