SQL Server 中将中文转为拼音首字母的函数及调用方法

编程入门 行业动态 更新时间:2024-10-27 19:23:48

SQL Server <a href=https://www.elefans.com/category/jswz/34/1771445.html style=中将中文转为拼音首字母的函数及调用方法"/>

SQL Server 中将中文转为拼音首字母的函数及调用方法

SQL Server 中将中文转为拼音首字母的函数及调用方法

原文地址:

1、创建函数

Create FUNCTION dbo.fnpbGetPYFirstLetter 
( 
@str NVARCHAR(4000) 
) 
/*
select dbo. fnpbGetPYFirstLetter ('中國香港')
*/
RETURNS NVARCHAR(4000) 
--WITH ENCRYPTION 
AS 
BEGIN 
DECLARE @WORD NCHAR(1),@PY NVARCHAR(4000) SET @PY='' WHILE LEN(@STR)>0 
BEGIN 
SET @WORD=LEFT(@STR,1) --如果非漢字字符﹐返回原字符 
SET @PY=@PY+(CASE WHEN UNICODE(@WORD) BETWEEN 19968 AND 19968+20901 
THEN ( 
SELECT TOP 1 PY 
FROM 
( 
SELECT 'A' AS PY,N'驁' AS WORD 
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'做' 
) T 
WHERE WORD>=@WORD COLLATE CHINESE_PRC_CS_AS_KS_WS 
ORDER BY PY ASC 
) 
ELSE @WORD 
END) 
SET @STR=RIGHT(@STR,LEN(@STR)-1) 
END RETURN @PY ENDGo

2、函数的调用

select dbo.fnpbGetPYFirstLetter(name), name from tablename
name:数据表中要转换为拼音首字母的字段




更多推荐

SQL Server 中将中文转为拼音首字母的函数及调用方法

本文发布于:2024-03-23 20:53:59,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1742712.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:中将   中文   函数   拼音   首字母

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!