<十六>JDBC_使用 DBUtils 编写通用的DAO
接口 : DAO<T>.java
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
/*
* 访问数据的DAO接口。
* @param T:DAO处理的实体类的类型
* */
public interface DAO<T> {
/*
* 批量处理的方法
* @param con:数据库连接
* @param sql:SQL语句
* @param args:填充占位符的Object[]类型的可变参数
* @return
* */
void batch(Connection con,String sql,Object[]...args);
/*
* 返回具体的一个值,eg.总人数,平均工资。。。
* @param con:数据库连接
* @param sql:SQL语句
* @param args:填充占位符的可变参数
* @return
* */
<E> E getForValue(Connection con,String sql,Object...args);
/*
* 返回一个T的一个集合
* @param con:数据库连接
* @param sql:SQL语句
* @param args:填充占位符的可变参数
* @return
* */
List<T> getForList(Connection con,String sql,Object...args);
/*
* 返回一个T的对象
* @param con:数据库连接
* @param sql:SQL语句
* @param args:填充占位符的可变参数
* @return
* */
T get(Connection con,String sql,Object...args) throws SQLException;
/*
* insert、update、delete
* @param con:数据库连接
* @param sql:SQL语句
* @param args:填充占位符的可变参数
* */
void update(Connection con,String sql,Object...args);
}
DAO接口实现类:JdbcDAOImpl.java
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import com.kk.jdbc.ReflectionUtils;
/*
* 使用QueryRunner提供其具体的实现
* @param<T>:子类需要传入泛型的类型
* */
public class JdbcDAOImpl<T> implements DAO<T> {
private QueryRunner qr=null;
private Class<T> type;
public JdbcDAOImpl() {
qr=new QueryRunner();
type=ReflectionUtils.getSuperGenericType(getClass());
}
@Override
public void batch(Connection con, String sql, Object[]... args) {
// TODO Auto-generated method stub
}
@Override
public <E> E getForValue(Connection con, String sql, Object... args) {
// TODO Auto-generated method stub
return null;
}
@Override
public List<T> getForList(Connection con, String sql, Object... args) {
// TODO Auto-generated method stub
return null;
}
@Override
public T get(Connection con, String sql, Object... args) throws SQLException {
return qr.query(con, sql, new BeanHandler<>(type), args);
}
@Override
public void update(Connection con, String sql, Object... args) {
// TODO Auto-generated method stub
}
}
JdbcDAOImpl的子类CustomerDao.java
public class CustomerDao extends JdbcDAOImpl<Customer> {
}
测试类:CustomerDaoTest.java
import static org.junit.Assert.*;
import java.sql.Connection;
import org.junit.Test;
import com.kk.jdbc.JDBCTools;
public class CustomerDaoTest {
CustomerDao customerDao=new CustomerDao();
@Test
public void testBatch() {
fail("Not yet implemented");
}
@Test
public void testGetForValue() {
fail("Not yet implemented");
}
@Test
public void testGetForList() {
fail("Not yet implemented");
}
@Test
public void testGet() {
Connection con = null;
try {
con=JDBCTools.getConnection();
String sql = "select id,name,email from customers where id=?";
Customer customer=customerDao.get(con, sql, 6);
System.out.println(customer);
} catch (Exception e) {
e.printStackTrace();
}finally{
JDBCTools.release(null, null, con);
}
}
@Test
public void testUpdate() {
fail("Not yet implemented");
}
}
<十六>JDBC_使用 DBUtils 编写通用的DAO的更多相关文章
- MYSQL 之 JDBC(十六): DBUtils
DBUtils是Apache组织提供的一个开源的JDBC工具类库,能极大简化jdbc编码的工作量 API介绍 QueryRunner ResultSetHandler 工具类DbUtils 用DBUt ...
- <十五>JDBC_使用 DBUtils 进行更新、查询操作
详解待续... DBUtilsTest.java import java.sql.Connection;import java.sql.Date;import java.sql.ResultSet;i ...
- 泛型理解及应用(二):使用泛型编写通用型Dao层
相信目前所有的IT公司网站在设计WEB项目的时候都含有持久层,同样地使用过Hibernate的程序员都应该看过或者了解过Hibernate根据数据库反向生成持久层代码的模板.对于Hibernate生成 ...
- <五>JDBC_利用反射及JDBC元数据编写通用的查询方法
此类针对javaBean类写了一个通用的查询方法,List<javaBean> 通用查询更新中...:通过学习,深刻体会到学会反射就等于掌握了java基础的半壁江山! 一.使用JDBC驱动 ...
- Java -- JDBC_利用反射及 JDBC 元数据编写通用的查询方法
先利用 SQL 进行查询,得到结果集: 利用反射创建实体类的对象:创建对象: 获取结果集的列的别名: 再获取结果集的每一列的值, 结合 3 得到一个 Map,键:列的别名,值:列的值: 再利用反射为 ...
- Flask 教程 第十六章:全文搜索
本文翻译自The Flask Mega-Tutorial Part XVI: Full-Text Search 这是Flask Mega-Tutorial系列的第十六部分,我将在其中为Microblo ...
- 编程艺术第十六~第二十章:全排列/跳台阶/奇偶调序,及一致性Hash算法
目录(?)[+] 第十六~第二十章:全排列,跳台阶,奇偶排序,第一个只出现一次等问题 作者:July.2011.10.16.出处:http://blog.csdn.net/v_JULY_v. 引言 ...
- Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制
在<Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明>中,我介绍了获取AccessToken(通用接口)的方法. 在实际的开发过程中,所有的高级接口都需 ...
- Java学习笔记(十六)——Java RMI
[前面的话] 最近过的好舒服,每天过的感觉很充实,一些生活和工作的技巧注意了就会发现,其实生活也是可以过的如此的有滋有味,满足现在的状况,并且感觉很幸福. 学习java RMI的原因是最近在使用dub ...
随机推荐
- Object-c 内存管理
内存管理 主要内容 1.内存管理的概念 2.引用计数 3.如何持有对象所有权 4.自动释放池 5.@property的使用 什么是内存管理 内存管理是关于如何管理对象生 ...
- 非旋treap模板
bzoj3580 非旋转treap 在大神教导下发现split一段区间时先split右边再split左边比较好写 #include <cstdio> #include <cstdli ...
- Spring学习(二)
1. AOP的思想(如何实现),AOP在哪些地方使用? 相关术语有哪些? AOP是面向切面编程,它是一种编程思想,采取横向抽取机制,取代了传统纵向继承体系重复性代码的方式 应用场景有: 记录日志 监控 ...
- PHP 继承多态知识点
//1.封装//目的:为了使类更加安全//做法://1.将成员变量变为私有的//2.在类里面做一个方法来间接的访问成员变量//3.在该方法里面加控制 //2.继承//1.父类//2.子类//子类可以继 ...
- squid 2.7 通过域名反向代理多个服务器的配置方法
详细配置及注释如下,供大家学习参考. visible_hostname squid1.abc.com #设定squid的主机名,如无此项squid将无法启动 http_port 80 accel vh ...
- 现有iOS项目集成React Native过程记录
在<Mac系统下React Native环境搭建>配置了RN的开发环境,然后,本文记录在现有iOS项目集成React Native的过程,官方推荐使用Cocoapods,项目一开始也是使用 ...
- sqlserver 中数据导入到mysql中的方法以及注意事项
数据导入从sql server 到mysql (将数据以文本格式从sqlserver中导出,注意编码格式,再将文本文件导入mysql中): 1.若从slqserver中导出的表中不包含中文采用: bc ...
- 爬虫requests模块 2
会话对象¶ 会话对象让你能够跨请求保持某些参数.它也会在同一个 Session 实例发出的所有请求之间保持 cookie, 期间使用 urllib3 的 connection pooling 功能.所 ...
- 【Java EE 学习 72 下】【数据采集系统第四天】【移动/复制页分析】【使用串行化技术实现深度复制】
一.移动.复制页的逻辑实现 移动.复制页的功能是在设计调查页面的时候需要实现的功能.规则是如果在同一个调查中的话就是移动,如果是在不同调查中的就是复制. 无论是移动还是复制,都需要注意一个问题,那就是 ...
- 【leetcode】Valid Parentheses
题目简述: Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if th ...