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)+'%')  

原文地址:https://www.cnblogs.com/JoeYD/p/12523201.html