JSP如何实现模糊查询,比如我有一个<input type="text" name="serach">

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JSP如何实现模糊查询,比如我有一个<input type="text" name="serach">相关的知识,希望对你有一定的参考价值。

JSP如何实现模糊查询,比如我有一个<input type="text" name="serach">,数据库是oracle,比如说表名是Student,字段名是name,name字段存有学生的姓名,我在文本框输入“张”,下面名字中有张的同学都显示在文本框附近,并且如果我点击了张三,那么文本框输入张三,如何获得我选择完“张三”这一时刻,文本框中的值?

参考技术A 这个最难的是把 相应的值显示在下边 参考技术B 可以用js来做 参考技术C 这个之前我实现过。前台用ajax做的,捕捉文本框输入动作,接着用ajax发送请求,后台接受请求,查询数据库。将相关的结果发送到前台。用下拉列表的方式展示。基本就是这样。网上应该有现成的例子

如何在java List中进行模糊查询

比如我有下面这样一个List,里面存放的是多个Employee对象。然后我想对这个List进行按照Employee对象的名字进行模糊查询。有什么好的解决方案么?
比如我输入的查询条件为“wang”,那么应该返回只包含employee1的List列表。

List list = new ArrayList();
Employee employee1 = new Employee();
employee1.setName("wangqiang");
employee1.setAge(30);
list.add(employee1);
Employee employee2 = new Employee();
employee2.setName("lisi");
list.add(employee2);
employee2.setAge(25);

方式一:

public List search(String name,List list){
   List results = new ArrayList();
   Pattern pattern = Pattern.compile(name);
   for(int i=0; i < list.size(); i++){
      Matcher matcher = pattern.matcher(((Employee)list.get(i)).getName());
      if(matcher.matches()){
         results.add(list.get(i));
      }
   }
   return results;
}

上面那个是大小写敏感的,如果要求大小写不敏感,改成:
Pattern pattern = Pattern.compile(name,Pattern.CASE_INSENSITIVE);

并且上面那个是精确查询,如果要模糊匹配,matcher.find()即可以进行模糊匹配

public List search(String name,List list){
   List results = new ArrayList();
   Pattern pattern = Pattern.compile(name);
   for(int i=0; i < list.size(); i++){
      Matcher matcher = pattern.matcher(((Employee)list.get(i)).getName());
      if(matcher.find()){
         results.add(list.get(i));
      }
   }
   return results;
}

方式二:

public class ListLike {

//定义员工类
public class Employee {
private String name;
private int age;
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}

public List list=new ArrayList();

//增加员工
public List addList(String name,int age){
Employee employee1 = new Employee();
employee1.setName(name);
employee1.setAge(age);
list.add(employee1);
return list;
}

//显示所有员工
public void ShowList(){
for(int i=0;i<list.size();i++){
System.out.println(((Employee)(list.get(i))).getName()+" "+((Employee)(list.get(i))).getAge());
}
}

//模糊查询
public List likeString(String likename){
for(int i=0;i<list.size();i++){
if(((Employee)(list.get(i))).getName().indexOf(likename)<=-1)
list.remove(i);
}
return list;

}

public static void main(String arg[]){
ListLike ll=new ListLike();
ll.addList("wuxiao",13);
ll.addList("wangwang",11);
ll.addList("wanghua",12);
ll.addList("xiaowang",13);
ll.addList("xiaoxiao",13);

ll.likeString("wang");
ll.ShowList();


}

}


以上是关于JSP如何实现模糊查询,比如我有一个<input type="text" name="serach">的主要内容,如果未能解决你的问题,请参考以下文章

jsp如何按指定条件进行模糊查询

JAVA项目/JSP页面 中 怎样实现模糊查询

jsp中要做一个 模糊查询 例如输入姓名时 输入“张”下拉框中即出现"张*、张**”等 代码该如何实现?

jsp 实现模糊查询

如何用java实现模糊查询

在JSP页面通过form表单传递5个模糊查询的条件 如何 在底层 写模糊查询 方法