目录


元数据概念

元数据 : 数据库、表、列的定义信息;( 就是一个信息的定义信息 ;)


DataBaseMetaData

DataBaseMetaData 数据库元数据对象 (- Connection.getDatabaseMetaData();)

    ·getURL(): 返回一个String类对象,代表数据的URL 。

    ·getUserName():返回连接当前数据库管理系统的用户名

    ·getDatabaseProductName(): 返回数据库的产品名称

    ·getDatabaseProduceVersion(): 返回数据库的版本号

    ·getDriverName(): 返回驱动程序的名称

    ·getDriverVersion(): 返回驱动程序的版本号

    ·isReadOnly() : 返回 boolean 值,指示数据库是否允许读操作 ;

ParameterMetaData

ParameterMetaData 参数的元数据

     ·PreparedStatement.getParameterMetaData():获得代表 sql参数的元数据的 ParamenterMetaData 对象

     ·getParameterCount() :获得指定sql语句的参数的个数

     ·getParameterType(int param) : 获得指定参数的sql类型 ;(mysql的驱动不支持)

ResultSetMetaData

ResultSetMetaData (从reasultSet上获取;代表ResultSet对象元数据)

    ·getColumnCount() :返回resultset对象的列数。

    ·getColumuName(int column) : 获得指定列的名称 ;

    ·getColumnTypeName(int column) : 获得指定列的类型 ;

编写简化版的JDBC

其实老方讲的就是明天要讲的dbutils的设计思路

在简化 查询 操作的时候,有一种思想在里面(策略模式,treeSet 也是这种模式)!

由于我们是框架设计者,在设计的时候,也不知道查询出来的是什么;

也不知道使用者,准备怎么处理结果集;

对于这种情况,我们就对外暴露一个接口,让使用者自己来写,他自己最清楚怎么操作结果集;

但是,我们也不能任何操作都让使用者自己写;

用你个查询,还要自己写个处理器;还不如使用原始的呢

因此,我们默认实现一些处理器接口的实现类,提供日常操作的实现类 ;

·BeanHandler 实现类 :

        构造器接受一个要返回对象的类型,方法内部使用反射进行赋值 ;

·BeanListHandler 实现类 :

        一样的思路;注意下结果集的游标,之前判断非空被移动到第一行了,再次查询之前需要将它移到表头,否则就从第二行开始查找了

O-R Mapping 概念

O-R Mapping简介

    ·什么是O-R Mapping 映射工具

        O: Object  对象 ;

        R:关系

        就是将对象关系映射到数据库里面 ;

    ·常用的O-R Mapping 映射工具

        ·Hibernate

        ·Ibatis

        ·Commons Dbutils(只是对JDBC 进行简单的封装)

自定义简化版JDBC


--------------------- 处理器接口 ------------------------- // 对外暴露的 处理器 接口
interface ResultSetHandler {
// 对 结果集 进行的操作
Object handler(ResultSet resultSet);
} ----------------------- 已实现类 -------------------------------- // 已实现类 将结果集数据封装到 bean 中
class BeanHandler implements ResultSetHandler { private Class clazz; public BeanHandler(Class clazz) {
this.clazz = clazz;
} @Override
public Object handler(ResultSet resultSet) {
try {
Object object = clazz.newInstance();
// 查询结果集中有多少行数据
ResultSetMetaData meta = resultSet.getMetaData();
int count = meta.getColumnCount(); for (int i = 0; i < count; i++) {
// 获取每列的字段的名字
String name = meta.getColumnName(i + 1);
System.out.println(name);
// 获取字段列的值
Object value = resultSet.getObject(name);
// 用反射技术,根据名字反射出字段
Field field = clazz.getDeclaredField(name);
// 破除掉 private 限制
field.setAccessible(true);
// 字段赋值
field.set(object, value);
} return object; } catch (Exception e) {
throw new RuntimeException(e);
}
}
} -------------------------- 已实现类 ----------------------------- // 已实现类 将结果集内容封装进 list 里面
class BeanListHandler implements ResultSetHandler {
private Class clazz; public BeanListHandler(Class clazz) {
this.clazz = clazz;
} @Override
public Object handler(ResultSet resultSet) {
try {
List list = new ArrayList();
// 需要将结果集游标往前移动一位,因为之前判断是否为空 往后移了一位
// 移到表头
resultSet.beforeFirst();
ResultSetMetaData meta = resultSet.getMetaData();
int count = meta.getColumnCount();
while (resultSet.next()) {
Object bean = clazz.newInstance();
for (int i = 0; i < count; i++) {
// 获得字段名字
String name = meta.getColumnName(i + 1);
// 反射出字段对象
Field field = clazz.getDeclaredField(name);
field.setAccessible(true);
// 通过resultSET查出结果
Object value = resultSet.getObject(name);
field.set(bean, value);
}
list.add(bean);
} return list;
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException(e);
}
}
} --------------------------简化版JDBC框架类---------------------------- // 简化版JDBC框架类
public class SimpleJdbcUtils { /**
* 先简化 增删改
*/
public static int update(String sql, Object[] objects) {
// 获取连接
Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet = null; try {
connection = JdbcC3P0Utils.getConnection();
statement = connection.prepareStatement(sql); // 循环赋值
for (int i = 0; i < objects.length; i++) {
statement.setObject(i + 1, objects[i]);
} return statement.executeUpdate(); } catch (Exception e) {
throw new ExceptionInInitializerError(e);
} finally {
JdbcC3P0Utils.closedConnection(resultSet, statement, connection);
} } /**
* 简化 查询 操作
*/
public static Object query(String sql, Object[] objects, ResultSetHandler handler) { Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet = null;
try {
connection = JdbcC3P0Utils.getConnection();
statement = connection.prepareStatement(sql); for (int i = 0; i < objects.length; i++) {
statement.setObject(i + 1, objects[i]);
} resultSet = statement.executeQuery(); if (!resultSet.next()) {
return null;
} return handler.handler(resultSet); } catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException(e);
} finally {
JdbcC3P0Utils.closedConnection(resultSet, statement, connection);
}
}
} ---------------------- 测试简化版JDBC ---------------------- // 增删改查 只需要3行代码。。
@Test
public void test1() {
String sql = "insert into employee(name,money) values(?,?)";
Object[] objects = {"qqqq", 12000};
SimpleJdbcUtils.update(sql, objects);
} @Test
public void test2() {
String sql = "update employee set money = ? where id = ?";
Object[] objects = {"14000", 1};
SimpleJdbcUtils.update(sql, objects);
} @Test
public void test3() {
String sql = "delete from employee where id = ?";
Object[] objects = {2};
SimpleJdbcUtils.update(sql, objects);
} @Test
public void test4() {
String sql = "select * from employee where id = ?";
Object[] objects = {4};
Employee employee = (Employee) SimpleJdbcUtils.query(sql, objects,new BeanHandler(Employee.class));
System.out.println(employee.getId());
System.out.println(employee.getMoney());
System.out.println(employee.getName());
} @Test
public void test5() {
String sql = "select * from employee ";
Object[] objects = {};
List<Employee> list = (List) SimpleJdbcUtils.query(sql, objects,new BeanListHandler(Employee.class)); for (int i = 0; i < list.size(); i++) {
System.out.print(list.get(i).getName()+" ");
System.out.print(list.get(i).getId()+" ");
System.out.print(list.get(i).getMoney()+" ");
System.out.println();
}

(二十二)自定义简化版JDBC(Dbutils框架的设计思想)的更多相关文章

  1. WCF技术剖析之二十二: 深入剖析WCF底层异常处理框架实现原理[中篇]

    原文:WCF技术剖析之二十二: 深入剖析WCF底层异常处理框架实现原理[中篇] 在[上篇]中,我们分别站在消息交换和编程的角度介绍了SOAP Fault和FaultException异常.在服务执行过 ...

  2. 使用Typescript重构axios(二十八)——自定义序列化请求参数

    0. 系列文章 1.使用Typescript重构axios(一)--写在最前面 2.使用Typescript重构axios(二)--项目起手,跑通流程 3.使用Typescript重构axios(三) ...

  3. Web 前端开发精华文章推荐(HTML5、CSS3、jQuery)【系列二十二】

    <Web 前端开发精华文章推荐>2014年第一期(总第二十二期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML ...

  4. JAVA基础知识总结:一到二十二全部总结

    >一: 一.软件开发的常识 1.什么是软件? 一系列按照特定顺序组织起来的计算机数据或者指令 常见的软件: 系统软件:Windows\Mac OS \Linux 应用软件:QQ,一系列的播放器( ...

  5. VMware vSphere 服务器虚拟化之二十二桌面虚拟化之创建View Composer链接克隆的虚拟桌面池

    VMware vSphere 服务器虚拟化之二十二桌面虚拟化之创建View Composer链接克隆的虚拟桌面池 在上一节我们创建了完整克隆的自动专有桌面池,在创建过程比较缓慢,这次我们将学习创建Vi ...

  6. 备忘录模式 Memento 快照模式 标记Token模式 行为型 设计模式(二十二)

    备忘录模式 Memento   沿着脚印,走过你来时的路,回到原点.     苦海翻起爱恨   在世间难逃避命运   相亲竟不可接近   或我应该相信是缘份   一首<一生所爱>触动了多少 ...

  7. 二十二. Python基础(22)--继承

    二十二. Python基础(22)--继承 ● 知识框架   ● 继承关系中self的指向 当一个对象调用一个方法时,这个方法的self形参会指向这个对象 class A:     def get(s ...

  8. (C/C++学习笔记) 二十二. 标准模板库

    二十二. 标准模板库 ● STL基本介绍 标准模板库(STL, standard template library): C++提供的大量的函数模板(通用算法)和类模板. ※ 为什么我们一般不需要自己写 ...

  9. FreeSql (二十二)Dto 映射查询

    适合喜欢使用 dto 的朋友,很多时候 entity 与 dto 属性名相同,属性数据又不完全一致. 有的人先查回所有字段数据,再使用 AutoMapper 映射. 我们的功能是先映射,再只查询映射好 ...

随机推荐

  1. openstack 无法创建新虚拟机报错 openstack报错:Host is not mapped to any cell

    关联错误提示:Host is not mapped to any cell 控制节点上执行: root@ubsv:/home/makeit# nova-manage cell_v2 discover_ ...

  2. Flask-CBV模式

    Flask中的CBV模式 ''' flask中的CBV模式: (1)导入views模块: from flask import views (2)定义类,继承views.MethodView类: cla ...

  3. 解决百度文字识别SDK拍照不回调问题

    在使用百度文字识别SDK的时候,发现点了拍照后camera.takePicture(ShutterCallback shutter, PictureCallback raw,PictureCallba ...

  4. Raspberry Pi 4B FTP服务器配置

    目录 1. 安装vsftpd并启动 2. 编辑配置文件 3. 重启服务 4. 测试 5. 为Web服务器添加管理员账户,便于通过ftp网站信息 参考资料:树莓派(raspberry pi)学习之安装f ...

  5. Qt自定义委托在QTableView中绘制控件、图片、文字

    自定义委托,继承于,QStyledItemDelegate类,重载Paint()函数, 1.实现在QTableView中绘制 格式字符串 2.实现在QTableView中绘制进度条 3.实现在QTab ...

  6. golang sqlx查询时, struct字段冲突

    type TA struct { Id int64 `db:"id"` } type TB struct { Id int64 `db:"id"` } type ...

  7. the requested PHP extension dom is missing from your system

    composer  出错 the requested PHP extension dom is missing from your system 解决办法    yum install  php70w ...

  8. Hive-概述

    Hive:由 Facebook 开源用于解决海量结构化日志的数据统计. Hive 是基于 Hadoop 的一个数据仓库工具,可以将结构化的数据文件映射为一张表,并提供类 SQL 查询功能. 本质是:将 ...

  9. linux查看文件具体时间和大小

    查看具体时间 ll --full-time 查看文件大小: ll -ht 或者du -sh *

  10. Pedro domingos

    Dear Professor:           I am a university student in China and study on MLN recently;             ...