利用jdbc写的一个类似DBUtils的框架

package com.jdbc.orm.dbutils;

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties; import com.jdbc.orm.handler.ResultsetHand; /**
*
* 功能描述:基于jdbc自己封装的orm小框架
*
*/
public class DBUtils {
public static String username;
public static String password;
public static String driverClass;
public static String url; public static Connection connection;
public static PreparedStatement statement;
public static ResultSet rs; static {
Properties properties = new Properties();
InputStream in = DBUtils.class.getClassLoader().getResourceAsStream("db.properties");
try {
properties.load(in);// 加载数据库的配置文件
driverClass = properties.get("jdbc.driverclass").toString();
username = properties.get("jdbc.username").toString();
password = properties.get("jdbc.password").toString();
url = properties.get("jdbc.url").toString();
} catch (IOException e) {
e.printStackTrace();
try {
Class.forName(driverClass);// 加载数据库的驱动程序
} catch (ClassNotFoundException e1) {
e1.printStackTrace();
}
}
} /**
*
* 功能 :为SQL语句设置参数
*
* @param sql
* 输入的sql语句
* @param params
* 需要的参数
* @throws SQLException
*/
public static void setParams(String sql, Object... params) throws SQLException {
connection = DriverManager.getConnection(url, username, password);
statement = connection.prepareStatement(sql);
if ( params != null && params.length > 0) {
for (int i = 0; i < params.length; i++) {
statement.setObject(i + 1, params[i]);
}
}
} /**
*
* @功能 :根据ID查询实体
* @param sql
* @param id
* @return 返回结果集
* @throws Exception
*/
public static ResultSet queryBeanById(String sql, int id) throws Exception {
setParams(sql, id);
return statement.executeQuery();
} /**
*
* @功能 :查询功能
* @param sql
* @param params
* @return 将查询到的结果映射到一个实体中返回
* @throws SQLException
*/
public static Object query(String sql, ResultsetHand rsh, Object... params) throws SQLException {
setParams(sql, params);
ResultSet rs = statement.executeQuery();
return rsh.handler(rs);
} /**
*
* @功能 :增删改功能
* @param sql
* @param params
* @throws SQLException
*/
public static int update(String sql, Object... params) throws SQLException {
setParams(sql, params);
return statement.executeUpdate();
} }
package com.jdbc.orm.handler;

import java.lang.reflect.Field;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.util.ArrayList;
import java.util.List; /**
* @描述 : 将查询到的结果映射到集合中
* @author 作者 jjkang
* @version 创建时间:2017年10月6日 下午8:04:46
*/
@SuppressWarnings("rawtypes")
public class BeanListHandler implements ResultsetHand {
private Class clazz; public BeanListHandler(Class clazz) {
this.clazz = clazz;
} @SuppressWarnings("unchecked")
@Override
public Object handler(ResultSet rs) {
List list = new ArrayList();
try { ResultSetMetaData metaData = rs.getMetaData();
int columnCount = metaData.getColumnCount();
while (rs.next()) {
Object bean = clazz.newInstance();
for (int i = 0; i < columnCount; i++) {
Object object = rs.getObject(i + 1);
String name = metaData.getColumnName(i + 1);
Field field = clazz.getDeclaredField(name);
field.setAccessible(true);
field.set(bean, object);
}
list.add(bean);
}
return list;
} catch (Exception e) {
throw new RuntimeException(e);
}
} }
package com.jdbc.orm.handler;

import java.lang.reflect.Field;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData; /**
* @描述 :将查询的结果映射到实体中
* @author 作者 E-mail: jiajunkang@outlook.com
* @version 创建时间:2017年10月6日 下午5:45:04
*/
public class BeanHandler implements ResultsetHand { private Class clazz;// 将结果映射到的实体 public BeanHandler(Class clazz) {
this.clazz = clazz;
} @Override
public Object handler(ResultSet rs) {
try {
if (!rs.next()) {
return null;
}
Object bean = clazz.newInstance();
ResultSetMetaData metaData = rs.getMetaData();
int columnCount = metaData.getColumnCount();
for (int i = 0; i < columnCount; i++) {
String name = metaData.getColumnName(i + 1);// 得出每一列的列名
Object value = rs.getObject(i + 1);// 得到每一列的值
Field field = clazz.getDeclaredField(name);// 利用反射,根据列名得到属性对象
field.setAccessible(true);
field.set(bean, value);
}
return bean;
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
package com.jdbc.orm.junit;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List; import org.junit.Test; import com.jdbc.orm.bean.Student;
import com.jdbc.orm.dbutils.DBUtils;
import com.jdbc.orm.handler.BeanHandler;
import com.jdbc.orm.handler.BeanListHandler; /**
* 描述 : 测试DBUtils
* @version 创建时间:2017年10月6日 下午2:40:45
*/
public class TestDBUtils {
DBUtils dbUtils = new DBUtils();
@Test
public void test(){
System.out.println(dbUtils.driverClass);
System.out.println(dbUtils.password);
System.out.println(dbUtils.url);
System.out.println(dbUtils.username);
} @Test
public void testSetParams() throws SQLException{
String sql = "select name from student where id = ?";
Object params[] = {1};
DBUtils.setParams(sql, params);
}
@Test
public void testQueryBeanById() throws Exception{
String sql = "select id,name,chinese,english,math from student where id = ?";
ResultSet rs=dbUtils.queryBeanById(sql, 1);
Student student = new Student(); while(rs.next()){
student.setId(rs.getInt(1));
student.setName(rs.getString(2));
student.setChinese(rs.getDouble(3));
student.setEnglish(rs.getDouble(4));
student.setMath(rs.getDouble(5));
}
System.out.println(student);
} @Test
public void testUpdate() throws SQLException{
String sql = "update student set name=? where id =?";
Object[] params = {"李晓明",1};
int rows = dbUtils.update(sql, params);
System.out.println(rows);
} @Test
public void testQuery() throws Exception{
String sql = "select id,name,chinese,english,math from student where id = ?";
Student student = new Student();
student = (Student) dbUtils.query(sql,new BeanHandler(Student.class), 1);
System.out.println(student);
}
@Test
public void testQuery1() throws Exception{
String sql = "select id,name,chinese,english,math from student";
List<Student> list = new ArrayList<>();
list = (List<Student>) dbUtils.query(sql,new BeanListHandler(Student.class), null);
System.out.println(list.size());
System.out.println(list);
}
}

利用jdbc简单封装一个小框架(类似DBUtils)的更多相关文章

  1. 一个小框架,基于rx_retrofit2_mvp

    离职在即,也没什么事情做,就鼓捣了一下.任意搭建了一个小框架,看看以后能不能搞出自己的一个model,好了.不说别的,上代码 1,先上依赖库 compile 'io.reactivex:rxandro ...

  2. JavaScript封装一个函数效果类似内置方法concat()

    JavaScript封装一个函数效果类似内置方法concat() 首先回忆concat()的作用: concat() 方法用于连接两个或多个数组.该方法不会改变现有的数组,而仅仅会返回被连接数组的一个 ...

  3. java的jdbc简单封装

    在学了jdbc一段时间后感觉自己写一个简单的封装来试试,于是參考的一些资料就写了一下不是多好,毕竟刚学也不太久 首先写配置文件:直接在src下建立一个db.properties文件然后写上内容 < ...

  4. 如何利用UDP协议封装一个数据包

    在如何封装一个数据包上,是一个非常细致的问题,而利用UDP协议来封装的话,是比较简单,让我们一步步来分析典型的TCP/IP协议.一般来说一个典型的一个数据包,包括以太网MAC头+网络层IP数据头+传输 ...

  5. 简单封装微信小程序

    一.不同环境配置封装 新建config文件夹,根据自己有不同环境设置不同的js文件 具体js文件内容: exports.config = { requestHost: 'https://******. ...

  6. 用XHR简单封装一个axios

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. Swift - 简单封装一个工具类模板

    创建模板类(封装一个类) 例1:新建一个名字叫做 Product 的类 Product.swift File 的内容 class Product { var name: String var desc ...

  8. js 利用throw 写的一个小程序

    在下边的小程序中比较特殊的是使用isNaN()函数判断一个参数是不是数字, <!DOCTYPE html> <!DOCTYPE html> <html> <h ...

  9. 利用ReentrantLock简单实现一个阻塞队列

    借助juc里的ReentrantLock实现一个阻塞队列结构: package demo.concurrent.lock.queue; import java.util.concurrent.lock ...

随机推荐

  1. Selenium常规操作---基于python

    from selenium import webdriver 1. 打开浏览器 driver=webdriver.Firefox()  #火狐浏览器 driver=webdriver.Ie()  #打 ...

  2. JavaScript学习日志(六):事件

    这篇随笔,深恶痛绝,敲到快结束的时候,凌晨00:19,突然闪退,也不知道是Mac的原因还是chrome的原因,重新打开的时候,以为自动保存有效果,心想没关系,结果他么的只保存了四分之一,WTF?!!! ...

  3. 201521123074 《Java程序设计》第7周学习总结

    1. 本周学习总结 以你喜欢的方式(思维导图或其他)归纳总结集合相关内容. (嗯..都画了那么久的导图,还是用导图归纳吧~) 2. 书面作业 ArrayList代码分析 1.1 解释ArrayList ...

  4. 201521123067 《Java程序设计》第6周学习总结

    1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 2. 书面作业 Q1:clone方法 1.1 Object ...

  5. 201521123060 《Java程序设计》第3周学习总结

    1. 本周学习总结 2. 书面作业 1.代码阅读 public class Test1 { private int i = 1;//这行不能修改 private static int j = 2; p ...

  6. 201521123098 JAVA课程设计

    1.团队课程设计博客链接 http://www.cnblogs.com/agts/p/7067948.html 2.个人负责模块或任务说明 个人任务:实现初始界面中的登录.注册模块,以及数据库的连接和 ...

  7. 201521123025<<java程序设计>>第9周学习总结

    1. 本周学习总结 2.书面作业 Q1.常用异常 题目5-1 1.1 截图你的提交结果(出现学号) 1.2 自己以前编写的代码中经常出现什么异常.需要捕获吗(为什么)?应如何避免? 经常出现Array ...

  8. 201521123068 《java程序设计》 第10周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容. 2. 书面作业 本次PTA作业题集异常.多线程 1.finally 题目4-2 1.1 截图你的提交结果(出 ...

  9. Junit4学习(六)Junit4参数化设置

    一,背景, 有时候会对相同的代码结构做同样的操作,不同的时对参数的设置数据和预期结果:有没有好的办法提取出来相同的代码,提高代码的可重用度,junit4中使用参数化设置,来处理此种场景: 二,代码展示 ...

  10. bookStore案例第一篇【部署开发环境、解决分类模块】

    前言 巩固Servlet+JSP开发模式,做一个比较完整的小项目 成果图 该项目包含了两个部分,前台和后台. 前台用于显示 后台用于管理 该项目可分为5个模块来组成:分类模块,用户模块,图书模块,购买 ...