SqlServer 获取汉字的拼音首字母

Posted 每天进步多一点

tags:

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

一、该函数传入字符串,返回数据为:如果为汉字字符,返回该字符的首字母,如果为非汉字字符,则返回本身。
二、用到的知识点:汉字对应的UNICODE值,汉字的排序规则。
三、数据库函数:

CREATE FUNCTION GetInitialLetter(@ChineseString NVARCHAR(4000)) 
RETURNS NVARCHAR(4000) 
AS
BEGIN
 
DECLARE @SingleCharacter NCHAR(1),
@ReturnString NVARCHAR(4000) 
SET @ReturnString = ‘‘ 

WHILE LEN(@ChineseString)>0 
BEGIN

--依次取单个字符
SET @SingleCharacter = LEFT(@ChineseString,1) 

----汉字字符,返回字符对应首字母,非汉字字符,返回原字符
IF(UNICODE(@SingleCharacter) BETWEEN 19968 AND 19968+20901)
SET @ReturnString = @ReturnString + 
(SELECT TOP 1 PY FROM
(SELECT ‘A‘ AS PY,N‘骜‘ AS ChineseCharacters 
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‘咗‘ 
)SpellingTable 
where ChineseCharacters > = @SingleCharacter COLLATE Chinese_PRC_CS_AS_KS_WS 
ORDER by PY ASC)
ELSE
SET @ReturnString = @ReturnString + @SingleCharacter
 
SET @ChineseString = RIGHT(@ChineseString,LEN(@ChineseString)-1) 

END
 
RETURN @ReturnString 

END
GO

SELECT dbo.GetInitialLetter(‘加油2018‘)

返回:JY2018

 



以上是关于SqlServer 获取汉字的拼音首字母的主要内容,如果未能解决你的问题,请参考以下文章

JS实现获取汉字首字母拼音全拼音及混拼音的方法

mysql 汉字按拼音字母排序获取拼音首字母拼音全拼

mysql 汉字按拼音字母排序获取拼音首字母拼音全拼

文本域输入汉字 第二个文本域立即显示汉字的获取首个字母 如何用JS实现

php获取汉字拼音首字母的方法

js中如何根据汉字生成拼音首字母