> 데이터 베이스 > MySQL 튜토리얼 > 获取中文名称的首字母

获取中文名称的首字母

WBOY
풀어 주다: 2016-06-07 14:54:53
원래의
1386명이 탐색했습니다.

用于获取中文名称的首字母 拼音 SQL Server CREATE FUNCTION getPinYin (@str varchar(500) = '') RETURNS varchar(500) AS /*-------------------用于获取中文名称的首字母---------------------------------*/BEGIN Declare @strlen int, @return varchar(5

用于获取中文名称的首字母 拼音 SQL Server
CREATE FUNCTION  getPinYin (@str varchar(500) = '')  
RETURNS varchar(500)  AS  

/*-------------------用于获取中文名称的首字母---------------------------------*/
BEGIN 
Declare @strlen int,
  @return varchar(500),
  @ii int,
  @c char(1),
  @chn nchar(1)
 --//初始化变量 
	 Declare @pytable table(
	 chn char(2) COLLATE Chinese_PRC_CS_AS NOT NULL,
	 py char(1) COLLATE Chinese_PRC_CS_AS NULL,
	 PRIMARY KEY (chn) 
	   )
	 insert into @pytable values('吖', 'A')
	 insert into @pytable values('八', 'B')
	 insert into @pytable values('嚓', 'C')
	 insert into @pytable values('咑', 'D')
	 insert into @pytable values('妸', 'E')
	 insert into @pytable values('发', 'F')
	 insert into @pytable values('旮', 'G')
	 insert into @pytable values('铪', 'H')
	 --insert into @pytable values('丌', 'I')
	 insert into @pytable values('丌', 'J')
	 insert into @pytable values('咔', 'K')
	 insert into @pytable values('垃', 'L')
	 insert into @pytable values('嘸', 'M')
	 insert into @pytable values('拏', 'N')
	 insert into @pytable values('噢', 'O')
	 insert into @pytable values('妑', 'P')
	 insert into @pytable values('七', 'Q')
	 insert into @pytable values('呥', 'R')
	 insert into @pytable values('仨', 'S')
	 insert into @pytable values('他', 'T')
	 --insert into @pytable values('屲', 'U')
	 --insert into @pytable values('屲', 'V')
	 insert into @pytable values('屲', 'W')
	 insert into @pytable values('夕', 'X')
	 insert into @pytable values('丫', 'Y')
	 insert into @pytable values('帀', 'Z')

 select @strlen = len(@str), @return = '', @ii = 0 
 --//循环整个字符串,用拼音的首字母替换汉字 
 while @ii < @strlen 
 begin
  select @ii = @ii + 1, @chn = substring(@str, @ii, 1)
     if @chn > 'z' --//检索输入的字符串中有中文字符
	   SELECT @c = max(py)
	   FROM @pytable
	   where chn <= @chn
    else
         set @c=@chn
 
  set @return=@return+@c 
 end
 return @return
END


로그인 후 복사
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿