拼音模糊查询实现
Posted joeyd
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了拼音模糊查询实现相关的知识,希望对你有一定的参考价值。
例如:模糊查询班级中所有姓 “李、刘” 的学生,只需要在查询的时候输入一个 “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)+‘%‘)
以上是关于拼音模糊查询实现的主要内容,如果未能解决你的问题,请参考以下文章