输入汉字拼音首字母即自动显示数据库中相应内容,急!在线等!!!

时间:2021-11-29 07:56:13
小弟遇到一个检索的问题。在一个文本框中输入字母在下面的列表中就显示出在数据库中以这个字母开头的所有数据。汉字的话就是拼音的首字母,英文的话就是首字母。就象管家婆和SQL帮助索引那样的功能。现在可以先考虑是汉字的情况。大家帮帮忙啊!!急用!

7 个解决方案

#1


那需要汉字字库哦,你看看用金山词霸把字库倒出来

#2


public class GetCh2Spell {
    public static int compare(String str1, String str2)
     {
         int result = 0;
         String m_s1 = null;
         String m_s2 = null;
         try
         {
             m_s1 = new String(str1.getBytes(_FromEncode_), _ToEncode_);
             m_s2 = new String(str2.getBytes(_FromEncode_), _ToEncode_);
         }
         catch(Exception e)
         {
             return str1.compareTo(str2);
         }
         result = chineseCompareTo(m_s1, m_s2);
         return result;
     }

     public static int getCharCode(String s)
     {
         if(s == null && s.equals(""))
             return -1;
         byte b[] = s.getBytes();
         int value = 0;
         for(int i = 0; i < b.length && i <= 2; i++)
             value = value * 100 + b[i];

         return value;
     }

     public static int chineseCompareTo(String s1, String s2)
     {
         int len1 = s1.length();
         int len2 = s2.length();
         int n = Math.min(len1, len2);
         for(int i = 0; i < n; i++)
         {
             int s1_code = getCharCode(s1.charAt(i) + "");
             int s2_code = getCharCode(s2.charAt(i) + "");
             if(s1_code * s2_code < 0)
                 return Math.min(s1_code, s2_code);
             if(s1_code != s2_code)
                 return s1_code - s2_code;
         }

         return len1 - len2;
     }

     public static String getBeginCharacter(String res)
     {
         String a = res;
         String result = "";
         for(int i = 0; i < a.length(); i++)
         {
             String current = a.substring(i, i + 1);
             if(compare(current, "\u554A") < 0)
                 result = result + current;
             else
             if(compare(current, "\u554A") >= 0 && compare(current, "\u5EA7") <= 0)
                 if(compare(current, "\u531D") >= 0)
                     result = result + "z";
                 else
                 if(compare(current, "\u538B") >= 0)
                     result = result + "y";
                 else
                 if(compare(current, "\u6614") >= 0)
                     result = result + "x";
                 else
                 if(compare(current, "\u6316") >= 0)
                     result = result + "w";
                 else
                 if(compare(current, "\u584C") >= 0)
                     result = result + "t";
                 else
                 if(compare(current, "\u6492") >= 0)
                     result = result + "s";
                 else
                 if(compare(current, "\u7136") >= 0)
                     result = result + "r";
                 else
                 if(compare(current, "\u671F") >= 0)
                     result = result + "q";
                 else
                 if(compare(current, "\u556A") >= 0)
                     result = result + "p";
                 else
                 if(compare(current, "\u54E6") >= 0)
                     result = result + "o";
                 else
                 if(compare(current, "\u62FF") >= 0)
                     result = result + "n";
                 else
                 if(compare(current, "\u5988") >= 0)
                     result = result + "m";
                 else
                 if(compare(current, "\u5783") >= 0)
                     result = result + "l";
                 else
                 if(compare(current, "\u5580") >= 0)
                     result = result + "k";
                 else
                 if(compare(current, "\u51FB") > 0)
                     result = result + "j";
                 else
                 if(compare(current, "\u54C8") >= 0)
                     result = result + "h";
                 else
                 if(compare(current, "\u5676") >= 0)
                     result = result + "g";
                 else
                 if(compare(current, "\u53D1") >= 0)
                     result = result + "f";
                 else
                 if(compare(current, "\u86FE") >= 0)
                     result = result + "e";
                 else
                 if(compare(current, "\u642D") >= 0)
                     result = result + "d";
                 else
                 if(compare(current, "\u64E6") >= 0)
                     result = result + "c";
                 else
                 if(compare(current, "\u82AD") >= 0)
                     result = result + "b";
                 else
                 if(compare(current, "\u554A") >= 0)
                     result = result + "a";
         }

         return result;
     }

     public static String getFirstStr(String str)
     {
         char a = str.charAt(0);
         char aa[] = {
             a
         };
         String sss = new String(aa);
         if(Character.isDigit(aa[0]))
             sss = "data";
         else
         if(a >= 'a' && a <= 'z' || a >= 'A' && a <= 'Z')
             sss = "character";
         else
             sss = getBeginCharacter(sss);
         return sss;
     }

     private static String _FromEncode_ = "GBK";
     private static String _ToEncode_ = "GBK";

}

获得汉字拼音首字母的java工具类(网上收集)

#3


调用楼上写的类的getFirstStr()方法返回的就是给方法里传的汉字的第一个汉字的第一个拼音字母。测试无误!

#4


up

#5


谢谢大家,不过还有一点差距,象sql帮助文档那样输入一个字母后有若干条记录,然后继续输入的话可以再次缩小范围。我想实现的是这个功能,jyh149129(风之刃)的回复我在文档区也看到过还有一篇是把汉字全部转化成字母的。正在研究中,希望大家能给出实现具体一点的方法,小弟刚学jsp不久很多不懂的,还请大家多多帮助。谢谢

#6


进行列表排序就可以

#7


和楼住说的一样 你可以在输入第二个字母的时候进行前两个字母的模糊查询 如where name like 'aa%'一个一个匹配下去就可以了 我的思路是这样的

#1


那需要汉字字库哦,你看看用金山词霸把字库倒出来

#2


public class GetCh2Spell {
    public static int compare(String str1, String str2)
     {
         int result = 0;
         String m_s1 = null;
         String m_s2 = null;
         try
         {
             m_s1 = new String(str1.getBytes(_FromEncode_), _ToEncode_);
             m_s2 = new String(str2.getBytes(_FromEncode_), _ToEncode_);
         }
         catch(Exception e)
         {
             return str1.compareTo(str2);
         }
         result = chineseCompareTo(m_s1, m_s2);
         return result;
     }

     public static int getCharCode(String s)
     {
         if(s == null && s.equals(""))
             return -1;
         byte b[] = s.getBytes();
         int value = 0;
         for(int i = 0; i < b.length && i <= 2; i++)
             value = value * 100 + b[i];

         return value;
     }

     public static int chineseCompareTo(String s1, String s2)
     {
         int len1 = s1.length();
         int len2 = s2.length();
         int n = Math.min(len1, len2);
         for(int i = 0; i < n; i++)
         {
             int s1_code = getCharCode(s1.charAt(i) + "");
             int s2_code = getCharCode(s2.charAt(i) + "");
             if(s1_code * s2_code < 0)
                 return Math.min(s1_code, s2_code);
             if(s1_code != s2_code)
                 return s1_code - s2_code;
         }

         return len1 - len2;
     }

     public static String getBeginCharacter(String res)
     {
         String a = res;
         String result = "";
         for(int i = 0; i < a.length(); i++)
         {
             String current = a.substring(i, i + 1);
             if(compare(current, "\u554A") < 0)
                 result = result + current;
             else
             if(compare(current, "\u554A") >= 0 && compare(current, "\u5EA7") <= 0)
                 if(compare(current, "\u531D") >= 0)
                     result = result + "z";
                 else
                 if(compare(current, "\u538B") >= 0)
                     result = result + "y";
                 else
                 if(compare(current, "\u6614") >= 0)
                     result = result + "x";
                 else
                 if(compare(current, "\u6316") >= 0)
                     result = result + "w";
                 else
                 if(compare(current, "\u584C") >= 0)
                     result = result + "t";
                 else
                 if(compare(current, "\u6492") >= 0)
                     result = result + "s";
                 else
                 if(compare(current, "\u7136") >= 0)
                     result = result + "r";
                 else
                 if(compare(current, "\u671F") >= 0)
                     result = result + "q";
                 else
                 if(compare(current, "\u556A") >= 0)
                     result = result + "p";
                 else
                 if(compare(current, "\u54E6") >= 0)
                     result = result + "o";
                 else
                 if(compare(current, "\u62FF") >= 0)
                     result = result + "n";
                 else
                 if(compare(current, "\u5988") >= 0)
                     result = result + "m";
                 else
                 if(compare(current, "\u5783") >= 0)
                     result = result + "l";
                 else
                 if(compare(current, "\u5580") >= 0)
                     result = result + "k";
                 else
                 if(compare(current, "\u51FB") > 0)
                     result = result + "j";
                 else
                 if(compare(current, "\u54C8") >= 0)
                     result = result + "h";
                 else
                 if(compare(current, "\u5676") >= 0)
                     result = result + "g";
                 else
                 if(compare(current, "\u53D1") >= 0)
                     result = result + "f";
                 else
                 if(compare(current, "\u86FE") >= 0)
                     result = result + "e";
                 else
                 if(compare(current, "\u642D") >= 0)
                     result = result + "d";
                 else
                 if(compare(current, "\u64E6") >= 0)
                     result = result + "c";
                 else
                 if(compare(current, "\u82AD") >= 0)
                     result = result + "b";
                 else
                 if(compare(current, "\u554A") >= 0)
                     result = result + "a";
         }

         return result;
     }

     public static String getFirstStr(String str)
     {
         char a = str.charAt(0);
         char aa[] = {
             a
         };
         String sss = new String(aa);
         if(Character.isDigit(aa[0]))
             sss = "data";
         else
         if(a >= 'a' && a <= 'z' || a >= 'A' && a <= 'Z')
             sss = "character";
         else
             sss = getBeginCharacter(sss);
         return sss;
     }

     private static String _FromEncode_ = "GBK";
     private static String _ToEncode_ = "GBK";

}

获得汉字拼音首字母的java工具类(网上收集)

#3


调用楼上写的类的getFirstStr()方法返回的就是给方法里传的汉字的第一个汉字的第一个拼音字母。测试无误!

#4


up

#5


谢谢大家,不过还有一点差距,象sql帮助文档那样输入一个字母后有若干条记录,然后继续输入的话可以再次缩小范围。我想实现的是这个功能,jyh149129(风之刃)的回复我在文档区也看到过还有一篇是把汉字全部转化成字母的。正在研究中,希望大家能给出实现具体一点的方法,小弟刚学jsp不久很多不懂的,还请大家多多帮助。谢谢

#6


进行列表排序就可以

#7


和楼住说的一样 你可以在输入第二个字母的时候进行前两个字母的模糊查询 如where name like 'aa%'一个一个匹配下去就可以了 我的思路是这样的