zoukankan      html  css  js  c++  java
  • C# 拼音模糊查询实现

    例如:模糊查询班级中所有姓 “李、刘” 的学生,只需要在查询的时候输入一个 “L” 进行查询。

    string PYM = "";
    foreach (char c in PersonName)
    {
    if ((int)c >= 33 && (int)c <= 126)
        {
        		//字母和符号原样保留     
        		PYM += c.ToString();
        }
        else
        {
        		//累加拼音声母     
        		PYM += GetPYChar(c.ToString());
        }
    }
    
    
    ///      
            /// 取单个字符的拼音声母     
            ///      
            /// 要转换的单个汉字     
            /// 拼音声母     
            public string GetPYChar(string c)
            {
                byte[] array = new byte[2];
                array = System.Text.Encoding.Default.GetBytes(c);
                int i = (short)(array[0] - '') * 256 + ((short)(array[1] - ''));
                if (i < 0xB0A1) return "*";
                if (i < 0xB0C5) return "a";
                if (i < 0xB2C1) return "b";
                if (i < 0xB4EE) return "c";
                if (i < 0xB6EA) return "d";
                if (i < 0xB7A2) return "e";
                if (i < 0xB8C1) return "f";
                if (i < 0xB9FE) return "g";
                if (i < 0xBBF7) return "h";
                if (i < 0xBFA6) return "j";
                if (i < 0xC0AC) return "k";
                if (i < 0xC2E8) return "l";
                if (i < 0xC4C3) return "m";
                if (i < 0xC5B6) return "n";
                if (i < 0xC5BE) return "o";
                if (i < 0xC6DA) return "p";
                if (i < 0xC8BB) return "q";
                if (i < 0xC8F6) return "r";
                if (i < 0xCBFA) return "s";
                if (i < 0xCDDA) return "t";
                if (i < 0xCEF4) return "w";
                if (i < 0xD1B9) return "x";
                if (i < 0xD4D1) return "y";
                if (i < 0xD7FA) return "z";
                return "*";
            }
    

     只需在人员表中新增PYM字段用来存放拼音码。

     模糊查询时  统一将输入内容转换成小写   转换操作在sqlserver中进行(最方便)

        实现sql:Select * from PerSon where PersonName like ('%'+@likeInfo+'%') or PYM like ('%'+LOWER(@likeInfo)+'%')  

  • 相关阅读:
    Python爬虫一
    Python爬虫二
    DRF框架中的演变View
    计算时间复杂度例题
    vue2.x webpack打包资源路径问题
    vs code运行c语言 控制台乱码 问题
    解决视频的声音和画面不同步问题
    c语言数据结构,静态链表,结构体数组
    swagger @ApiModel添加实体类不生效
    计算及校验海明码的3个举例
  • 原文地址:https://www.cnblogs.com/JoeYD/p/12523201.html
Copyright © 2011-2022 走看看