<十五>JDBC_使用 DBUtils 进行更新、查询操作
详解待续。。。
DBUtilsTest.java
import java.sql.Connection;
import java.sql.Date;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Test;
import com.kk.jdbc.JDBCTools;
public class DBUtilsTest {
/*
* ScalarHandler:把结果集转为一个数值(可以是任意基本数据类型和字符串,Date等)返回
* */
@Test
public void testScalarHandler(){
Connection con = null;
try {
con=JDBCTools.getConnection();
String sql = "select count(id) from customers";
Object result=qr.query(con, sql, new ScalarHandler());
System.out.println(result);
} catch (Exception e) {
e.printStackTrace();
}finally{
JDBCTools.release(null, null, con);
}
}
/*
* MapListHandler:将结果集转为一个Map的List,
* Map对应查询的一条记录,键:SQL查询的列名(不是列的别名),值:列的值
* MapListHandler返回的是多条记录对应的Map的集合
* */
@Test
public void testMapListHandler(){
Connection con = null;
try {
con=JDBCTools.getConnection();
String sql = "select name from customers where id=?";
List<Map<String,Object>> result = (List<Map<String, Object>>) qr.query(con, sql, new MapListHandler());
System.out.println(result);
} catch (Exception e) {
e.printStackTrace();
}finally{
JDBCTools.release(null, null, con);
}
}
/*
* MapHandler:返回SQL对应的第一条记录对应的Map对象;
* 键:SQL查询的列名(不是列的别名)
* 值:列的值
* */
@Test
public void testMapHandler(){
Connection con = null;
try {
con=JDBCTools.getConnection();
String sql = "select id,name,email,birth from customers";
Map<String,Object> result = (Map<String, Object>) qr.query(con, sql, new MapHandler());
System.out.println(result);
} catch (Exception e) {
e.printStackTrace();
}finally{
JDBCTools.release(null, null, con);
}
}
/*
* BeanListHandler:把结果集转为一个List,该List不为空,但可能为空集合(size()方法返回0)
* 若SQL语句能够查询到记录,List中存放创建BeanListHandler传入的Class对象对应的对象。
* */
@Test
public void testBeanListHandler(){
Connection con = null;
try {
con=JDBCTools.getConnection();
String sql = "select id,name,email,birth from customers";
List<Customer> customers = (List<Customer>) qr.query(con, sql, new BeanListHandler(Customer.class));
System.out.println(customers);
} catch (Exception e) {
e.printStackTrace();
}finally{
JDBCTools.release(null, null, con);
}
}
/*
* BeanHandler:把结果集的第一条记录转为创建BeanHandler对象时传入的Class参数对应的对象
* */
@Test
public void testBeanHandler(){
Connection con = null;
try {
con=JDBCTools.getConnection();
String sql = "select id,name,email,birth from customers where id=?";
Customer customer=(Customer) qr.query(con, sql, new BeanHandler(Customer.class), 6);
System.out.println(customer);
} catch (Exception e) {
e.printStackTrace();
}finally{
JDBCTools.release(null, null, con);
}
}
// 1、创建QueryRunner的实现类
QueryRunner qr = new QueryRunner();
/*
* QueryRunner的query方法的返回值取决于ResultSetHandler参数的handle方法的返回值
* */
@Test
public void testQuery() {
Connection con = null;
class MyResultSetHandler implements ResultSetHandler{
@Override
public Object handle(ResultSet rs) throws SQLException {
List<Customer> customers=new ArrayList<>();
while(rs.next()){
Integer id=rs.getInt(1);
String name=rs.getString(2);
String email=rs.getString(3);
Date birth=rs.getDate(4);
Customer customer=new Customer(id,name,email,birth);
customers.add(customer);
}
return customers;
}
}
try {
con = JDBCTools.getConnection();
String sql = "select id,name,email,birth from customers";
Object ob=qr.query(con, sql, new MyResultSetHandler());
System.out.println("谢荣康:"+ob);
} catch (Exception e) {
e.printStackTrace();
}finally{
JDBCTools.release(null, null, con);
}
}
/**
* 测试 QueryRunner类的update方法(insert 、update、delete)
*/
@Test
public void testQueryRunnerUpdate() {
// 2、使用update方法
String sql = "delete from customers where id in (?,?)";
Connection con = null;
try {
con = JDBCTools.getConnection();
qr.update(con, sql, 2, 5);
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCTools.release(null, null, con);
}
}
}
<十五>JDBC_使用 DBUtils 进行更新、查询操作的更多相关文章
- 第十五章、python中的进程操作-开启多进程
目录 第十五章.python中的进程操作-开启多进程 一.multprocess模块 二.multprocess.process模块 三.Process()对象方法介绍 四.Process()对象属性 ...
- USB学习笔记连载(十五):USB固件更新以及安装驱动
前几篇博客已经把如何更改固件程序和更改USB驱动名称,那么接下来就要把之前生成的 .iic 文件烧录到EEPROM里面去,实现USB的C2启动(笔者使用的是此类型,C2启动). 打开Cypress U ...
- <十六>JDBC_使用 DBUtils 编写通用的DAO
接口 : DAO<T>.java import java.sql.Connection;import java.sql.SQLException;import java.util.List ...
- [ExtJS5学习笔记]第三十五节 sencha extjs 5 组件查询方法总结
一个UI前台组件肯定会比较多,我们通常习惯性的使用ID来获取需要操作的组件,但是这种方法是extjs推荐的么?有没有extjs推荐使用的获取组件的方法呢? 目录 目录 extjs的查询组件的API 查 ...
- Python学习第二十五课——Mysql (多表查询)
多表查询: 内连接查询: 首先:创建两个表一个为tableA,一个为tableB,并且插入数据(代码省略) 同时查询两个表的记录: select * from tableA,tableB; 根据tab ...
- UWP开发入门(十五)——在FlipView中通过手势操作图片
本篇的最终目的,是模拟系统的照片APP可以左右滑动,缩放图片的操作.在实现的过程中,我们会逐步分析UWP编写UI的一些思路和技巧. 首先我们先实现一个横向的可以浏览图片的功能,也是大部分APP中的实现 ...
- (十五)Hibernate中的多表操作(5):双向多对多
Hibernate的双向关联. 对象之间可以相互读取. 双向只针对读取的操作.对于增.删除.改的操作没有任何影响. 案例 : 实现双向多对多 MenuBean.java package ...
- FreeSql (十五)查询数据
FreeSql在查询数据下足了功能,链式查询语法.多表查询.表达式函数支持得非常到位. IFreeSql fsql = new FreeSql.FreeSqlBuilder() .UseConnect ...
- 第三百六十五节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的基本查询
第三百六十五节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的基本查询 1.elasticsearch(搜索引擎)的查询 elasticsearch是功能 ...
随机推荐
- winserver 08 64位安装sql05 64位提示asp版本注册
将打开 安装IIS 6.0的就可以了,然后重启下
- 已知当前地理位置经纬度查询几个点中最近的一个地点demo
1.首先定义一个点与点之间测算距离的方法 2.然后定义找出基本点和集合中最近的一个点的方法 3.取第一条数据即是最近的点的坐标 public class Location { public int i ...
- MFC 按钮如何改变颜色
我们发现想改变对话框的背景颜色是很简单的,但是对话框的背景颜色改变了后,我们发现按钮的颜色没有改变,如下图. 这样做出来的对话框看起来,不是很自然,我们也想把按钮的颜色改变一下.这就用到了按钮的重绘. ...
- Range Sum Query 2D - Immutable
https://leetcode.com/problems/range-sum-query-2d-immutable/ 条件说sumRegion 会调很多次,如果每次都用双for 循环去累加的话就有太 ...
- ElasticSearch的基本用法与集群搭建
一.简介 ElasticSearch和Solr都是基于Lucene的搜索引擎,不过ElasticSearch天生支持分布式,而Solr是4.0版本后的SolrCloud才是分布式版本,Solr的分布式 ...
- 【leetcode】Valid Parentheses
题目简述: Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if th ...
- Java集合框架练习-计算表达式的值
最近在看<算法>这本书,正好看到一个计算表达式的问题,于是就打算写一下,也正好熟悉一下Java集合框架的使用,大致测试了一下,没啥问题. import java.util.*; /* * ...
- Javascript-常用字符串数组操作
字符串的操作在编写Js的过程中是不可避免的 因为它太多的API 还有相似的API让我们很头痛 为了避免以后遇到模拟两可的问题 还是做个笔记比较好 把常用的字符串操作记录下来成笔记 方便以后查找 No1 ...
- js类数组
类数组 - [ Array-like ] : objects 1. what's Array-like 类数组和数组很像,但是数组的很多方法却不能用,这就很尴尬了~ 像 arguments.nodel ...
- 《UML大战需求分析》阅读随笔(五)
在处理复杂事物的时候,用到一种基本手段就是抽象.抽象的目的是区别事物之间的本质和不同,面向对象编程(OOP)的实质就是利用 类和对象来建立抽象模型. 类表示对象的类别,是创建对象的蓝本.建立一个事物的 ...