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;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/106656.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • MTCNN工作原理「建议收藏」

    MTCNN工作原理「建议收藏」MTCNN工作原理MTCNN是什么MTCNN,Multi-taskconvolutionalneuralnetwork(多任务卷积神经网络),将人脸区域检测与人脸关键点检测放在了一起,基于cascade框架。总体可分为PNet、RNet、和ONet三层网络结构,MTCNN实现流程构建图像金字塔首先讲图像进行不同尺度的变换,构建图像金字塔,以适应不同大小的人脸的进行检测。…

  • taglib配置_tablib

    taglib配置_tablibtld文件放入META-INF中取名taglib.tldweb.xml中配置     XXXX   /WEB-INF/lib/包名.jar   

    2022年10月28日
  • 安装NGINX_nginx安装步骤

    安装NGINX_nginx安装步骤Linux安装Nginx1、下载官方下载地址:http://nginx.org/en/download.htmlnginx-1.20.2下载wgethttp://nginx.org/download/nginx-1.20.2.tar.gz2、依赖安装yum-yinstallgcczlibzlib-develpcre-developensslopenssl-devel3、编译安装3.1、解压tar-zxvfnginx-1.20.2.tar.gz3.2

  • import上一级目录的模块(Python)

    import上一级目录的模块(Python)

  • termux安装kali图形界面_kali如何创建shell脚本

    termux安装kali图形界面_kali如何创建shell脚本解决方法:在终端输入以下命令行:sudogedit/usr/share/applications/Pycharm.desktop1进入gedit文档界面然后将里面的内容复制成:[DesktopEntry]Type=ApplicationName=PycharmGenericName=Pycharm3Comment=Pycharm3:ThePythonIDEExec=…

  • 银河麒麟安装qt开发环境_优麒麟怎么样

    银河麒麟安装qt开发环境_优麒麟怎么样1.如果你对中标麒麟系统安装有疑问,请阅读上一篇文章:《中标麒麟/NeoKylinU盘安装系统》。2.进入系统打开终端,以root模式操作。&lt;1&gt;yuminstallgstream*libXext-devellibX11-devel&lt;2&gt;ln-s/usr/lib64/libXrender.so.1.3.0/usr/lib64/libXrend…

发表回复

您的电子邮箱地址不会被公开。

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