<十五>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是功能 ...
随机推荐
- mybatis Oracle 批量插入,批量更新
传入的参数只要是list类型的参数就行了..............1.批量插入<insert id="insertBatch" parameterType="ja ...
- Eclipse下载与安装
有很多小伙伴不知道eclipse在哪里下载以及怎么安装的,那我来给大家做个演示吧. 学习java比较常用的软件就是eclipse,而eclipse安装后并不能马上使用,还需要安装jdk并搭建环境.下面 ...
- Java POI 解析word文档
实现步骤: 1.poi实现word转html 2.模型化解析html 3.html转Map数组 Map数组(数组的操作处理不做说明) 1.导jar包. 2.代码实现 package com.web.o ...
- SQL 隐藏手机号中间四位
SELECT INSERT(mobile, 4, 4, '****')AS Mobile from Users ;
- oracle 存储过程的用法
create or replace procedure myPro(inParams in number,outParams out number) is str varchar(200); beg ...
- NYOJ之题目1058部分和问题
---------------------------------------- 简单搜索+剪枝 因为考虑到可能会有多个解,所以是将中间过程保存最后才一起打印出来的 AC代码: 1: 2: impor ...
- C 标准库系列之limits.h
limits.h 类似于float.h,其定义了一些列类型的值的范围.限制值,也就是说该类型的值不可以大于该上界或者小于该类型值的下界: glibc中宏定义了一下的值: # define MB_LEN ...
- collection of vim vim tutorial for beginner
在linux命令行下编辑文档 http://blog.csdn.net/niushuai666/article/details/7275406 http://linuxconfig.org/vim-t ...
- 结合谷歌地图多边形(polygon)与Sql Server 2008的空间数据类型计算某个点是否在多边形内的注意事项
首先在利用 GEOGRAPHY::STPolyFromText(@GeoStr, 4326) 这样的函数把字符串转换为Geography类型时,字符串里经纬度的顺序是 “经度[空格]纬度”,即“lon ...
- windows下mysql客户端输入中文显示??解决方法
>>>>>>>>>>>>>>>>>>>> 1.检查并修改mysql的my.ini ...