全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Java中JDBC实现动态查询的实例详解

一 概述

1.什么是动态查询?

从多个查询条件中随机选择若干个组合成一个DQL语句进行查询,这一过程叫做动态查询。

2.动态查询的难点

可供选择的查询条件多,组合情况多,难以一一列举。

3.最终查询语句的构成

一旦用户向查询条件中输入数据,该查询条件就成为最终条件的一部分。

二 基本原理

1.SQL基本框架

无论查询条件如何,查询字段与数据库是固定不变的,这些固定不变的内容构成SQL语句的基本框架,如

select column... from table。

2.StringBuilder形成DQL

获取表单输入,如果请求参数非空,根据该请求参数生成查询条件,如“name=?”,“age>?”,将查询条件追加到基本框架中。利用StringBuilder来追加查询条件,这时出现一个问题,怎么判断生成的查询条件中是否需要添加“and”?
如果该查询条件是第一个查询条件,不需要添加"and",否则需要添加“and”。问题变得复杂起来,每一次生成查询条件时都需要判断前面是否存在查询条件。

我们可以考虑在SQL基本框架中添加一个查询条件,该查询条件的存在不影响查询结果,只充当占位角色,避免动态添加查询条件时判断是否需要添加“and”。根据这些要求,这一查询条件必须恒为真,这里我们取“1=1”,SQL基本框架就变成了

select column...from table where 1=1

每一个动态查询条件前段都添加“and”。

3.List集合为占位符赋值

有了DQL语句,接着需要考虑怎么为占位符赋值。可以在生成查询条件的同时,将占位符对应的参数收集起来,存入一个有序集合中,这里选择List集合,这样占位符就与List集合中的元素形成了顺序上的对应关系,第n个占位符对应第n个元素,遍历集合就可以为占位符赋值了。
为占位符赋值时,不仅仅需要将数据传递给占位符,还需要选择与字段一致的数据类型,List集合仅仅存储数据已经不能够满足要求了,还需要添加字段信息,以区分不同的字段,选择不同的数据类型。这里集合中的元素采用“column+data”的形式。

三 Demo

1.数据库

2.页面

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<style>
span {
  display: inline-block;
  width: 75px;
  margin-bottom: 15px;
}
</style>
<title>动态查询</title>
</head>
<body>
  <form action="http://localhost:8080/JavaSETest/dynamicQueryServlet">
    <div>
      <span>姓名:</span><input type="text" name="name">
    </div>
    <div>
      <span>性别:</span><input type="text" name="sex">
    </div>
    <div>
      <span>年龄:</span><input type="text" name="age">
    </div>
    <div>
      <span>部门编号:</span><input type="text" name="depNo">
    </div>
    <div>
      <input type="submit"value="查询">&nbsp;<input type="reset"value="重置">
    </div>
  </form>
</body>
</html>

3.服务器端(Servlet)

package com.javase.jdbc;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/dynamicQueryServlet")
public class DynamicQueryServlet extends HttpServlet {
  private static final long serialVersionUID = 1L;
  @Override
  protected void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    response.setContentType("text/html;charset=UTF-8");
    // 获取请求参数
    String name = request.getParameter("name");
    String sex = request.getParameter("sex");
    String age = request.getParameter("age");
    String depNo = request.getParameter("depNo");
    // 关键是"where 1=1",不需要再判断追加的查询条件前是否需要添加and,统一在前面添加and
    String baseSQL = "select name,sex,age,depNo from tb_employee where 1=1";
    StringBuilder builder = new StringBuilder();// 用于拼接SQL语句
    // 用于在占位符与参数值之间建立映射,占位符与参数值在各自序列中的排序一相同,例如name的占位符在SQL语句中排第一,name的参数值在
    // 集合中排第一。
    List<String> params = new ArrayList<String>();
    builder.append(baseSQL);
    if (isNotEmpty(name)) {
      builder.append(" and name=? ");
      params.add("name," + name);// 集合中不能仅仅存储具体的数据,还要存储字段名,以便后续根据字段名选择数据类型
    }
    if (isNotEmpty(sex)) {
      builder.append(" and sex=? ");
      params.add("sex," + sex);
    }
    if (isNotEmpty(age)) {
      builder.append(" and age=? ");
      params.add("age," + age);
    }
    if (isNotEmpty(depNo)) {
      builder.append(" and depNo=?");
      params.add("depNo," + depNo);
    }
    Connection conn = null;
    PreparedStatement ps = null;
    ResultSet res = null;
    StringBuilder resStr = new StringBuilder();
    try {
      conn = getConnection();
      ps = conn.prepareStatement(builder.toString());
      for (int i = 0; i < params.size(); i++) {
        String str = params.get(i);
        String[] arr = str.split(",");//arr[0]储存字段信息,用于区分字段;arr[1]存储数据,用于为占位符赋值
        // 因为为占位符赋值时,需要根据字段类型选择数据类型,所以在此判断类型
        if (arr[0].equals("age")) {
          int a = Integer.parseInt(arr[1]);
          ps.setInt(i + 1, a);
        } else {
          ps.setString(i + 1, arr[1]);
        }
      }
      res = ps.executeQuery();
      while (res.next()) {
        String targetName = res.getString("name");
        String targetSex = res.getString("sex");
        int targetAge = res.getInt("age");
        String targetDepNo = res.getString("depNo");
        String temp = "name=" + targetName + "--" + "sex=" + targetSex + "--" + "age=" + targetAge + "--"
            + "depNo=" + targetDepNo;
        resStr.append(temp + "<br>");
      }
    } catch (ClassNotFoundException | SQLException e) {
      e.printStackTrace();
    } finally {
      if (res != null)
        try {
          res.close();
        } catch (SQLException e) {
          e.printStackTrace();
        }
      if (ps != null)
        try {
          ps.close();
        } catch (SQLException e) {
          e.printStackTrace();
        }
      if (conn != null)
        try {
          conn.close();
        } catch (SQLException e) {
          e.printStackTrace();
        }
    }
    PrintWriter out = response.getWriter();
    int length = resStr.length();
    if (length == 0)
      out.write("查询为空");
    else
      out.write(builder.toString() + "<br>" + resStr.toString());
  }
  /**
   * 判断请求参数是否存在,是否有数据输入
   * 
   * @param str
   * @return
   */
  private boolean isNotEmpty(String str) {
    if (str == null | str.equals("")) {
      return false;
    }
    return true;
  }
  public static Connection getConnection() throws ClassNotFoundException, SQLException {
    Class.forName("com.mysql.jdbc.Driver");
    return DriverManager.getConnection("jdbc:mysql://localhost:3366/test01", "root", "123");
  }
}

以上所述是小编给大家介绍的Java中JDBC实现动态查询的实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# jdbc  # 动态查询  # Java基础开发之JDBC操作数据库增删改查  # 分页查询实例详解  # Java使用Jdbc连接Oracle执行简单查询操作示例  # JDBC连接MySql数据库步骤 以及查询、插入、删除、更新等  # 使用jdbcTemplate查询返回自定义对象集合代码示例  # 使用JDBC从数据库中查询数据的方法  # JDBC使用游标实现分页查询的方法  # java实现jdbc查询结果集result转换成对应list集合  # JDBC查询Map转对象实现过程详解  # 这一  # 在此  # 还需要  # 小编  # 是否存在  # 字段名  # 中排  # 第一个  # 多个  # 不需要  # 遍历  # 我们可以  # 形成了  # 给大家  # 就可  # 一个问题  # 要将  # 不需  # 在前面  # 表单 


相关文章: 如何快速搭建支持数据库操作的智能建站平台?  如何在橙子建站中快速调整背景颜色?  网站按钮制作软件,如何实现网页中按钮的自动点击?  免费ppt制作网站,有没有值得推荐的免费PPT网站?  如何快速搭建二级域名独立网站?  如何快速配置高效服务器建站软件?  如何选择域名并搭建高效网站?  如何用y主机助手快速搭建网站?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  临沂网站制作公司有哪些,临沂第四中学官网?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  已有域名能否直接搭建网站?  广平建站公司哪家专业可靠?如何选择?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  设计网站制作公司有哪些,制作网页教程?  深圳网站制作的公司有哪些,dido官方网站?  建站之星后台管理:高效配置与模板优化提升用户体验  c++怎么用jemalloc c++替换默认内存分配器【性能】  深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何通过商城免费建站系统源码自定义网站主题?  C++中引用和指针有什么区别?(代码说明)  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  高性价比服务器租赁——企业级配置与24小时运维服务  如何通过VPS搭建网站快速盈利?  建站之星24小时客服电话如何获取?  建站OpenVZ教程与优化策略:配置指南与性能提升  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  Java解压缩zip - 解压缩多个文件或文件夹实例  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  如何使用Golang安装API文档生成工具_快速生成接口文档  网站app免费制作软件,能免费看各大网站视频的手机app?  详解jQuery停止动画——stop()方法的使用  ,制作一个手机app网站要多少钱?  微课制作网站有哪些,微课网怎么进?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  建站主机是否等同于虚拟主机?  高端建站如何打造兼具美学与转化的品牌官网?  如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  文字头像制作网站推荐软件,醒图能自动配文字吗?  制作农业网站的软件,比较好的农业网站推荐一下?  深圳网站制作案例,网页的相关名词有哪些?  如何彻底卸载建站之星软件?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。