sqlserver 獲取漢字拼音的首字母(大寫)函數


1:創建函數:

USE [test]
GO
/****** 對象:  UserDefinedFunction [dbo].[GetFirstChar]    腳本日期: 02/22/2019 16:39:06 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--創建中文截取字符函數
ALTER FUNCTION [dbo].[GetFirstChar](@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

2:看結果:

謝歡的童鞋點個贊那~


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM