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

  • 相关阅读:
    MySQL与Navicat的安装及使用教程
    数据结构与算法1
    Spring Cloud Gateway 聚合 Swagger
    Linux上GitLab+Jenkins实现Vue、Spring Cloud项目的自动部署
    JPA and ( or )
    How to autowire RestTemplate using annotations
    MyBatis的解析和运行原理(源码分析)
    MyBatis映射器总结
    什么是泛型?泛型的基本原理与使用优势。
    MyBatis配置总结
  • 原文地址:https://www.cnblogs.com/JoeYD/p/12523201.html
Copyright © 2011-2022 走看看