zoukankan      html  css  js  c++  java
  • 字符集--获取中文首字母拼音

    --============================================
    --创建辅助表
    IF(OBJECT_ID('dbo.PinYinFirst','U') IS NOT NULL)
    BEGIN
    DROP TABLE dbo.PinYinFirst
    END
    GO
    CREATE TABLE dbo.PinYinFirst
    (
     Word NVARCHAR(200),
     PY NVARCHAR(200)
    )
    GO
    --=======================================
    --插入数据
    INSERT INTO dbo.PinYinFirst(PY,Word)
    SELECT 'A' AS py, N'吖' AS chn
    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'丌' --because have no 'i'
    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'帀'
    --=======================================
    --创建函数,循环遍历字符串,
    --使用辅助表来获取遍历得到的字符的拼音首字符
    IF(OBJECT_ID('dbo.ufn_GetPyFirst','FN') IS NOT NULL)
    BEGIN
    DROP FUNCTION dbo.ufn_GetPyFirst
    END
    GO
    CREATE FUNCTION dbo.ufn_GetPyFirst(@Str NVARCHAR(500)='')
    RETURNS NVARCHAR(500)
    AS
    BEGIN
     
     DECLARE @strlen INT;
     SELECT @strlen=LEN(@str);
     DECLARE @i INT;
     DECLARE @result NVARCHAR(500);
     SET @result=N''
     SET @i=0;
     --空字符串返回空
     IF(@strlen<1)
     BEGIN
     RETURN '';
     END
     
     WHILE(@i<@strlen)
     BEGIN
     SET @i=@i+1
     DECLARE @tempChar NCHAR(1);
     DECLARE @tempPY NCHAR(1);
     SET @tempChar=substring(@str,@i,1);
     IF(@tempChar>N'z')
     BEGIN
     SELECT TOP(1) @tempPY=T.py FROM dbo.PinYinFirst T
     WHERE T.word<=@tempChar
     ORDER BY T.word
     COLLATE Chinese_PRC_CI_AS DESC;
     
     SET @result=@result+@tempPY;
     END
     END
     RETURN @result
    END
    GO
    --==============================
    --测试
    select dbo.ufn_GetPyFirst(N'好人N')

  • 相关阅读:
    freeswitch对媒体的处理的三种方式
    Windows如何在cmd命令行中查看、修改、删除与添加、设置环境变量
    freeswitch电话代接
    freeswitch三方通话配置
    认识拨号计划
    洛谷P4049 [JSOI2007]合金 题解
    2020-9杂题选做
    LOJ#6497. 「雅礼集训 2018 Day1」图 题解
    LOJ#6496. 「雅礼集训 2018 Day1」仙人掌 题解
    LOJ#6495. 「雅礼集训 2018 Day1」树 题解
  • 原文地址:https://www.cnblogs.com/TeyGao/p/3522699.html
Copyright © 2011-2022 走看看