JAVA中DBUtils的QueryRunner类实现增删改查详解

JAVA中DBUtils的QueryRunner类实现增删改查详解JAVA中DBUtils的QueryRunner类实现增删改查详解

大家好,又见面了,我是你们的朋友全栈君。

一.QueryRunner类实现增删改

连接池代码:JdbcUtil.java

package com.wb.util;

/** * c3p0,dbcp,druid */
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

import javax.sql.DataSource;

import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.pool.DruidDataSourceFactory;

/** * 绝对不能使用单例 * * @author Administrator 硬编码 */
public class JdbcUtil { 
   
    private static Connection con = null;
    private static DataSource ds = null;
    private static Properties pt = null;
    static { 
   
        // 1.获得当前类的加载器
        ClassLoader cl = JdbcUtil.class.getClassLoader();
        // 通过该加载器得到一个输入流
        InputStream in = cl.getResourceAsStream("jdbc.properties");
        // 通过输入创一个properties对象
        pt = new Properties();
        try { 
   
            pt.load(in);
        } catch (IOException e) { 
   
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    public static Connection getCon() { 
   

        if (ds == null) { 
   
            try { 
   
                ds = (DruidDataSource) DruidDataSourceFactory.createDataSource(pt);
            } catch (Exception e) { 
   
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        try { 
   
            return ds.getConnection();
        } catch (SQLException e) { 
   
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return null;
    }
    public static void closeCon(Connection con) { 
   
        try { 
   
            con.close();
        } catch (SQLException e) { 
   
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

具体使用模板:

   publicstaticvoidmain(String[] args)throws Exception{ 
   //使用自己的工具类,获取数据库的连接对象

Connection conn = MyJDBCUtils.getConnection();//创建QueryRunner类对象
QueryRunner qr =newQueryRunner(); 
String sql ="UPDATE gjp_ledger set money=? , ldesc=? where lid=?"; 
Object[] params ={ 
   998,"买钻石",3};int result = qr.update(conn, sql, params); 
System.out.println(result); 
DbUtils.close(conn);}

二.QueryRunner类获取查询结果集ResultSetHandler

1.常用Handler

  • ArrayHandler 将结果集第一行转成对象数组
  publicstaticvoidmain(String[] args)throws Exception{ 
    
  Connection conn = MyJDBCUtils.getConnection(); 
  String sql ="SELECT * FROM gjp_ledger where lid=?"; 
  //结果集处理方式,ArrayHandler 第一行转成对象数组
  QueryRunner qr =newQueryRunner(); 
  Object[] objects = qr.query(conn, sql,newArrayHandler(),3);
  for(Object obj : objects){ 
    
  System.out.println(obj); 
  } 
  }
  • ArrayListHandler 将结果集中的每一行数据都转成一个对象数组,再将转成的多个对象数组存放到List
  publicstaticvoidmain(String[] args)throws Exception{ 
    
  Connection conn = MyJDBCUtils.getConnection(); 
String sql ="SELECT * FROM gjp_ledger"; 
QueryRunner qr =newQueryRunner();//执行query方法,传递连接对象,SQL语句,结果集处理方式
ArrayListHandler 
List<Object[]> list = qr.query(conn, sql,newArrayListHandler());for(Object[] objects : list){ 
   for(Object obj : objects){ 
    
System.out.print(obj+" ");} 
System.out.println();}}
  • BeanHandler 将结果集第一行数据封装到一个对应的业务类实例中
    (1): 定义业务数据类Ledger(实体类,javaBean)
publicclassLedger{ 
   //要生成空参、有参构造、set和get方法、toString方法
privateint lid;private String parent;privatedouble money;privateint sid;private String account;private String createtime;private String ldesc;}

(2)测试案例代码

publicstaticvoidmain(String[] args)throws Exception{ 
    
Connection conn = MyJDBCUtils.getConnection(); 
String sql ="SELECT * FROM gjp_ledger"; 
QueryRunner qr =newQueryRunner();//BeanHandler泛型,构造方法(和反射有关系的对象) 
Ledger legder = qr.query(conn, sql,newBeanHandler<Ledger>(Ledger.class)); 
System.out.println(legder);}
  • BeanListHandler 将结果集中的每一行数据都封装到一个对应的业务类实例中,再将多个业务类实例对象存放到List里。
publicstaticvoidmain(String[] args)throws Exception { 
    
Connection conn = MyJDBCUtils.getConnection(); 
String sql ="SELECT * FROM gjp_ledger";//结果集处理方式,BeanListHandler 每一行数据封装到业务数据类中
QueryRunner qr =newQueryRunner(); 
List list = qr.query(conn, sql,newBeanListHandler(Ledger.class));for(Ledger ledger : list){ 
    
System.out.println(ledger);}}
  • MapHandler 将结果集中的第一行数据封装到一个Map中,key是列名,value是对应的值。
  publicstaticvoidmain(String[] args)throws Exception { 
    
Connection conn = MyJDBCUtils.getConnection(); 
String sql ="SELECT * FROM gjp_ledger";//结果集处理方式,MapHandler 封装到一个Map集合中,存储键值对集合
QueryRunner qr =newQueryRunner(); 
Map<String,Object> map = qr.query(conn, sql,newMapHandler());for(String key : map.keySet()){ 
    
System.out.println(key+" "+map.get(key));}}
  • MapListHandler 将结果集中的每一行数据都封装到一个Map里,然后再将多个Map存放到List
   publicstaticvoidmain(String[] args)throws Exception{ 
    
Connection conn = MyJDBCUtils.getConnection(); 
String sql ="SELECT * FROM gjp_ledger";//结果集处理方式,MapListHandler 数据中的每一行封装成Map集合,多个Map集合存储到List集合
QueryRunner qr =newQueryRunner(); 
List<Map<String,Object>> list = qr.query(conn, sql,newMapListHandler());for(Map<String,Object> map : list){ 
   for(String key : map.keySet()){ 
    
System.out.print(key+" "+map.get(key));} 
System.out.println();

多表联合查询

 QueryRunner qr = new QueryRunner();

    @Override
    public List<Emp> getEmpList(Integer pageSize, Integer pageIndex, String empName) { 
   
        List<Emp> empList = new ArrayList<Emp>();
       /* //使用new BeanListHandler<>(Emp.class);会导致集合里面字段为空 Connection con = JdbcUtil.getCon(); String sql = "select emp_id empId,emp_name empName,emp_phone empPhone,emp_age empAge,emp_sex empSex,e.depa_id depaId, d.depa_name depaName FROM emp e INNER JOIN depa d ON e.depa_id=d.depa_id WHERE e.emp_name like ? limit ?,?"; try { empList = qr.query(con, sql, new BeanListHandler<>(Emp.class), empName == null || "".equals(empName) ? "%%" : "%" + empName + "%", (pageIndex - 1) * pageSize, pageSize); } catch (SQLException e) { e.printStackTrace(); } finally { JdbcUtil.closeCon(con); } for (int i = 0; i < empList.size(); i++) { System.out.println(empList.get(i)); }*/
        
        //使用 new MapListHandler() 需要手动遍历
        Connection con = JdbcUtil.getCon();
        String sql = "select emp_id,emp_name,emp_phone,emp_age,emp_sex,e.depa_id, depa_name FROM emp e INNER JOIN depa d ON e.depa_id=d.depa_id WHERE e.emp_name like ? limit ?,?";
        try { 
   
            List<Map<String,Object>> list = qr.query(con, sql, new MapListHandler(),
                    empName == null || "".equals(empName) ? "%%" : "%" + empName + "%",
                    (pageIndex - 1) * pageSize, pageSize);
           for(Map<String,Object> map:list){ 
   
               Emp emp = new Emp();
               for(String key: map.keySet()){ 
   
                   switch (key) { 
   
                case "emp_id":
                    emp.setEmpId((Integer) map.get(key));
                    break;
                case "emp_sex":
                    emp.setEmpSex((String) map.get(key));
                    break;
                case "emp_age":
                    emp.setEmpAge((Integer) map.get(key));
                    break;
                case "emp_phone":
                    emp.setEmpPhone((String) map.get(key));
                    break;
                case "emp_name":
                    emp.setEmpName((String) map.get(key));
                    break;
                case "depa_id":
                    emp.setDepaId((Integer) map.get(key));
                    break;
                case "depa_name":
                    emp.setDepaName((String) map.get(key));
                    break;

                default:
                    System.out.println("发生异常");
                    break;
                }
                   //System.out.println(key+"---"+map.get(key));
               }
               empList.add(emp);
           }

        } catch (SQLException e) { 
   
            e.printStackTrace();
        } finally { 
   
            JdbcUtil.closeCon(con);
        }
        for (int i = 0; i < empList.size(); i++) { 
   
            System.out.println(empList.get(i));
        }
        return empList;
    }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106654.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SVN—SVN服务器搭建和使用[通俗易懂]

    本系列会总结一些svn和git的安装和使用,以及最后svn的项目如何迁移到git上,整个系列会持续输出。 要学习svn,那么首先开始搭建svn服务器和客户端。 下面要讲的有:svn下载和安装svn配置文件svn服务器的使用1:svn服务器和客户端安装包下载和安装 Subversion是优秀的版本控制工具, 现在Subversion已经迁移到apache网站上了,下载地址: http://

    2022年2月25日
    46
  • Oracle insert all 详解

    Oracle insert all 详解文章目录1概述2insert的两种形式2.1insertfirst2.2insertall3数据一致性(同时插入)2.1验证:insertinto数据不一致2.2验证:insertall数据一致1概述1.作用:’正确、高效’的将’同一批数据’插入至’不同的表’中2.好处(1)’正确’:避免数据差异(2)’高效’:优于写多个insertinto(因为无论插入多少张表,’主表’只会被读取一次)3.场景,若需求:将表t中

    2022年7月25日
    18
  • Android直播开发之旅(10):AndroidUSBCamera,UVCCamera开发通用库(支持开启多路摄像头)[通俗易懂]

    Android直播开发之旅(10):AndroidUSBCamera,UVCCamera开发通用库(支持开启多路摄像头)[通俗易懂]AndroidUSBCamera基于[saki4510t/UVCCamera](https://github.com/saki4510t/UVCCamera)开发,该项目对USBCamera(UVC设备)的使用和视频数据采集进行了高度封装,能够帮助开发者通过几个简单的API实现USBCamera设备的检测、连接、预览和音视频数据采集,最重要的是手机无需root,只需支持otg功能即可驱………

    2022年8月13日
    3
  • intellij idea 激活码(JetBrains全家桶)

    (intellij idea 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~B…

    2022年3月22日
    65
  • 常用的英文单词2000

    常用的英文单词2000常用的英文单词,可以ctrl+f来查找需要的单词,查找需要的前缀后缀引导的单词1a[ei,ə]art.一(个);任何一(个);每一(个)2I[ai]pron.我3ability[əbiliti]n.能力,本领;才能,才智4able[eibəl]a.能够…的,得以…的;有才干的5about[əbaut]prep.关于;在…周围ad.大约;在附近6ab…

    2022年6月23日
    23
  • 9-ICMP报文种类「建议收藏」

    9-ICMP报文种类「建议收藏」1.ICMP报文种类  ICMP报文的种类分为两种:一种是差错报告报文,另一种是查询报文。  对于差错报告报文来说,ICMP总是把差错报文报告给发送数据源端(源主机)。比如:主机A给主机发送一个数据,结果这个数据在网络传输过程中出错了,然后ICMP协议的机制就会返回一个差错报告给主机A(相当于把数据在传输过程中出错的信息发回给主机A)。2.差错报告报文差错报告报文常见有以下…

    2022年5月1日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号