mysql和SqlServer 中取得漢字字段的各漢字首字母


mysql 中取得漢字字段的各漢字首字母

這個轉載於http://blog.csdn.net/lky5387/article/details/11973721

DELIMITER ;;
CREATE  FUNCTION `getPY`(in_string VARCHAR(65534)) RETURNS mediumtext CHARSET utf8
BEGIN
DECLARE tmp_str VARCHAR(65534) charset gbk DEFAULT '' ; #截取字符串,每次做截取后的字符串存放在該變量中,初始為函數參數in_string值
DECLARE tmp_len SMALLINT DEFAULT 0;#tmp_str的長度
DECLARE tmp_char VARCHAR(2) charset gbk DEFAULT '';#截取字符,每次 left(tmp_str,1) 返回值存放在該變量中
DECLARE tmp_rs VARCHAR(65534) charset gbk DEFAULT '';#結果字符串
DECLARE tmp_cc VARCHAR(2) charset gbk DEFAULT '';#拼音字符,存放單個漢字對應的拼音首字符
SET tmp_str = in_string;#初始化,將in_string賦給tmp_str
SET tmp_len = LENGTH(tmp_str);#初始化長度
WHILE tmp_len > 0 DO #如果被計算的tmp_str長度大於0則進入該while
SET tmp_char = LEFT(tmp_str,1);#獲取tmp_str最左端的首個字符,注意這里是獲取首個字符,該字符可能是漢字,也可能不是。
SET tmp_cc = tmp_char;#左端首個字符賦值給拼音字符
IF LENGTH(tmp_char)>1 THEN#判斷左端首個字符是多字節還是單字節字符,要是多字節則認為是漢字且作以下拼音獲取,要是單字節則不處理。
SELECT ELT(INTERVAL(CONV(HEX(tmp_char),16,10),0xB0A1,0xB0C5,0xB2C1,0xB4EE,0xB6EA,0xB7A2,0xB8C1,0xB9FE,0xBBF7,0xBFA6,0xC0AC
,0xC2E8,0xC4C3,0xC5B6,0xC5BE,0xC6DA,0xC8BB,0xC8F6,0xCBFA,0xCDDA ,0xCEF4,0xD1B9,0xD4D1),
'A','B','C','D','E','F','G','H','J','K','L','M','N','O','P','Q','R','S','T','W','X','Y','Z') INTO tmp_cc; #獲得漢字拼音首字符
END IF;
SET tmp_rs = CONCAT(tmp_rs,tmp_cc);#將當前tmp_str左端首個字符拼音首字符與返回字符串拼接
SET tmp_str = SUBSTRING(tmp_str,2);#將tmp_str左端首字符去除
SET tmp_len = LENGTH(tmp_str);#計算當前字符串長度
END WHILE;
RETURN tmp_rs;#返回結果字符串
END;;
DELIMITER ;

效果圖:

SqlServer 中取得漢字字段的各漢字首字母


--將中文字符串轉化成文字首拼音的組合
create function dbo.fun_getPY(@str nvarchar(4000))
returns nvarchar(4000)
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
end
GO

效果圖

很實用的兩個自定義函數,積累總是一點一點的。

 


免責聲明!

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



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