利用jdbc简单封装一个小框架(类似DBUtils)
利用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)的更多相关文章
- 一个小框架,基于rx_retrofit2_mvp
离职在即,也没什么事情做,就鼓捣了一下.任意搭建了一个小框架,看看以后能不能搞出自己的一个model,好了.不说别的,上代码 1,先上依赖库 compile 'io.reactivex:rxandro ...
- JavaScript封装一个函数效果类似内置方法concat()
JavaScript封装一个函数效果类似内置方法concat() 首先回忆concat()的作用: concat() 方法用于连接两个或多个数组.该方法不会改变现有的数组,而仅仅会返回被连接数组的一个 ...
- java的jdbc简单封装
在学了jdbc一段时间后感觉自己写一个简单的封装来试试,于是參考的一些资料就写了一下不是多好,毕竟刚学也不太久 首先写配置文件:直接在src下建立一个db.properties文件然后写上内容 < ...
- 如何利用UDP协议封装一个数据包
在如何封装一个数据包上,是一个非常细致的问题,而利用UDP协议来封装的话,是比较简单,让我们一步步来分析典型的TCP/IP协议.一般来说一个典型的一个数据包,包括以太网MAC头+网络层IP数据头+传输 ...
- 简单封装微信小程序
一.不同环境配置封装 新建config文件夹,根据自己有不同环境设置不同的js文件 具体js文件内容: exports.config = { requestHost: 'https://******. ...
- 用XHR简单封装一个axios
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Swift - 简单封装一个工具类模板
创建模板类(封装一个类) 例1:新建一个名字叫做 Product 的类 Product.swift File 的内容 class Product { var name: String var desc ...
- js 利用throw 写的一个小程序
在下边的小程序中比较特殊的是使用isNaN()函数判断一个参数是不是数字, <!DOCTYPE html> <!DOCTYPE html> <html> <h ...
- 利用ReentrantLock简单实现一个阻塞队列
借助juc里的ReentrantLock实现一个阻塞队列结构: package demo.concurrent.lock.queue; import java.util.concurrent.lock ...
随机推荐
- 边看MHA源码边学Perl语言之一开篇
边看MHA源码边学Perl语言之一开篇 自我简介 先简单介绍一下自己,到目前为此我已经做了7年左右的JAVA和3年左右php开发与管理,做java时主要开发物流行业的相关软件,对台湾快递,国际快递,国 ...
- iOS js oc相互调用(JavaScriptCore 下)
下来我们使用js调用iOS js调用iOS分两种情况 一,js里面直接调用方法 二,js里面通过对象调用方法 首先我们看第一种,直接调用方法. 其中用到了iOS的block 上代码 -(void)we ...
- javascript计算啤酒2元一瓶,4个盖换一瓶,2个瓶换一瓶,10元钱最多喝多少瓶
var n = 0//当前剩下多少瓶加上喝赢了多少瓶 var x = 5//初始多少瓶 var y = 0//除了喝掉的,剩下多少瓶 var z = 0;//总数 var arr = []//定义一个 ...
- .net asp mvc 如何从后端返回数据对象
今天在做项目时,有一个需求:获取从控制器返回的数组对象,方法如下 public ActionResult GetAllFiles() { string dir = Server.MapPath(&qu ...
- Beta阶段事后诸葛亮分析
1.总结的提纲内容 a. 项目管理之事后诸葛亮会 设想和目标 1.我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件主要解决用户无意识花钱,无法清楚看见钱去 ...
- 微信小程序scroll标签的测试
一:testscroll.wxml的代码如下.testview.js自动生成示例代码 //testscroll.wxml <view class="section__title&quo ...
- 团队作业8——第二次项目冲刺(Beta阶段)--第七天
会议照片: 燃尽图: 项目进展: 所有项目都已完成 进行app测试即使用情况评估 团队贡献比: 队员 角色 团队贡献比 陈麟凤 PM 17% 张志杰 DEV 18% 黄海鸿 TEST 16% 康建灿 ...
- 201521123085 《JAVA程序设计》第6周学习总结
1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 2. 书面作业 1.clone方法 1.1 Object对 ...
- 201521123099《java程序设计》第五周学习总结
本周学习总结 1.1 尝试使用思维导图总结有关多态与接口的知识点. 2. 书面作业 代码阅读:Child压缩包内源代码 1.1 com.parent包中Child.java文件能否编译通过?哪句会出现 ...
- 201521145048 《Java程序设计》第3周学习总结
1. 本章学习总结 学会了对于一个基本类的创建,需要有属性(private public protected),方法( 静态方法 非静态方法),构造函数,main函数,在定义属性时一般使用privat ...