参考:http://blog.csdn.net/liuhenghui5201/article/details/16369773

一、

1、加载驱动--》》封装    ---》》静态代码块

2、连接数据库--》》封装    ---》》返回Connection类型

3、执行SQL语句

4、处理得到的结果集

5、关闭连接--》》封装

3、4封装到数据访问对象Dao类,1、2、5封装到DBUtils类

 private final static String URL = "jdbc:oracle:thin:@localhost:1521:orcl";
 private final static String USER = "aa";
 private final static String PWD = "aa";
 static{
     try {
         Class.forName("oracle.jdbc.driver.OracleDriver");
     } catch (ClassNotFoundException e) {
         // TODO Auto-generated catch block
         e.printStackTrace();
     }
 }

上述代码写在DBUtils类中,封装在静态代码块类似于单例形式,即只需要一次调用加载驱动

扩展:ThreadLocal类       ---绑定本地线程,常用的get( ),set( ),remove( )方法

set( T value): 将value值加入本地线程中

get( ): 从本地线程中取值

remove( ):

目的:JVM为每一个运行的线程,绑定了私有的本地实例存储空间

解决问题:多线程环境中(同步),为了解决多线程中对同一变量的访问冲突

方法:1)、可以直接创建本地线程对象,并通过泛型指定线程绑定的数据类型

private static ThreadLocal<Connection> threadLocal = new ThreadLocal<Connection>();

2)、

事务处理:批量操作

conn.setAutoComit(false);设置提交方式为手工提交

conn.commit()提交事务

出现异常,回滚 conn.rollback();

二、数据访问对象Dao    ---通常一张表对应一个Dao,命名规范 :表名Dao

1、addXxx( )    ---对应INSERT

updateXxx( )

deleteXxx( )

queryAllData( )    ---select ... from

queryById( )   --select ... from  ... where  id = ?

三、PreparedStatement接口

----表示预编译的 SQL 语句的对象。

----SQL 语句被预编译并存储在 PreparedStatement 对象中。然后可以使用此对象多次高效地执行该语句。

四、查询数据,返回结果集

1、解析方法:

将单条记录封装到一个JavaBean对象中,每一列的值对应Bean一个属性

将若干个Bean封装到List集合,返回该List

2、JavaBean  ---主要用于封装,传递数据对象,它是一个普通的java类,命名规则:表名Bean

构成:私有属性,属性的前三个字母必须小写

各属性的set/get方法,

默认构造方法

扩展:循环的两种方法

 List<MyUserBean> list = dao.queryAllData();    //创建一个数组来接收返回的数组

 Iterator<MyUserBean> it = list.iterator();     //方法1:Iterator循环,需要理解Iterator的原理
 while (it.hasNext()) {
     MyUserBean myUserBean = (MyUserBean) it.next();  //得到MyUserBean中的一条记录
     System.out.println(myUserBean.getUname());
 }

 for(MyUserBean it2 : list){                           //方法2:for循环
     System.out.println(it2.getUname());
 }

五、根据Id查询

多表连接查询:

因为多表连接查询的列是不固定的,所以,不能创建JavaBean存储单条记录,改用Map对象

将每一条记录  --》》封装到Map对象

将若干条记录对象(Map对象)  --》》封装到List列表中

返回List

ResultSetMetaData 接口:取得结果集中的元数据

六、BaseDao封装

可变长参数:              ---语法:数据类型 ... 形参名

---必须写在参数列表的最后一个且只有一个,可以当成数组使用,

查询操作在BaseDao里的封装有两种方案:

1)、查询后返回ResultSet让子类自己解析结果集

2)、根据项目需求,封装成某种特定数据类型

七、单值封装

java系列-JDBC的封装的更多相关文章

  1. java的jdbc简单封装

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

  2. java系列--JDBC连接oracle

    <oracle开发实战经典><oracle DBA从入门到精通> JDBC连接数据库 JNDI连接池 oracle.jdbc.driver.OracleDriver 其实就是一 ...

  3. Java通过JDBC 进行Dao层的封装

    前言 前面有一章节,我专门讲解了Java通过JDBC 进行MySQL数据库操作,这主要讲解了MySQL数据库的连接和简单的操作,但是在真正的Java项目中,我们要不断的和数据库打交道,为了提高数据库操 ...

  4. java:Oracle(Jdbc的封装)和HTML(登录,注册,个人信息界面)

    1.Oracle Jdbc的封装: public class TestJdbc { // 把jdbc需要的属性,全部私有化 private static final String DRIVER = & ...

  5. Java基础系列1:Java基本类型与封装类型

    Java基础系列1:Java基本类型与封装类型 当初学习计算机的时候,教科书中对程序的定义是:程序=数据结构+算法,Java基础系列第一篇就聊聊Java中的数据类型. 本篇聊Java数据类型主要包括两 ...

  6. Java的JDBC操作

    Java的JDBC操作 [TOC] 1.JDBC入门 1.1.什么是JDBC JDBC从物理结构上来说就是java语言访问数据库的一套接口集合,本质上是java语言根数据库之间的协议.JDBC提供一组 ...

  7. Java系列笔记(2) - Java RTTI和反射机制

    目录 前言 传统的RTTI 反射 反射的实现方式 反射的性能 反射与设计模式 前言 并不是所有的Class都能在编译时明确,因此在某些情况下需要在运行时再发现和确定类型信息(比如:基于构建编程,),这 ...

  8. Java使用Jdbc操作MySql数据库(一)

    这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...

  9. 【转】O'Reilly Java系列书籍建议阅读顺序(转自蔡学庸)

    Learning Java the O'Reilly's Way (Part I) Java 技术可以说是越来越重要了,不但可以用在计算机上,甚至连电视等家电用品,行动电话.个人数字助理(PDA)等电 ...

随机推荐

  1. 2015十大顶级开源ERP系统点评

    如今,企业资源规划(ERP)和客户关系管理(CRM)系统的必要性已经被各种组织和企业所认可:ERP和CRM能够直接为企业的业务效率和利润做出贡献. 但是随着今天企业商业形态的日趋多样化,互联网新经济的 ...

  2. Oracle sql语句创建表空间、数据库、用户及授权

    --创建表空间和数据库文件及默认表空间大小 create tablespace TableSpace_Test datafile 'E:\ORACLE\PRODUCT\10.2.0\ORADATA\O ...

  3. hdu_5718_Oracle(大数模拟)

    题目连接:hdu_5718_Oracle 题意: 给你一串数,让你分出两个正整数,使其和最大,若不能分出来就输出"Uncertain" 题解: 当时比赛的时候还天真的去搞大数模版, ...

  4. Android Studio 修改主题

    http://jingyan.baidu.com/article/6f2f55a18040aeb5b93e6cb4.html

  5. Ubuntu系统如何卸载并安装新版本的jdk(permission denied问题)

    1.如果是自带的openjdk运行下面可以删除: sudo apt-get purge openjdk* 但是这种情况又不一定成功,有时候运行java -version发现还是可以运行的.证明删除不成 ...

  6. UIView 面面观

    原创:转载请注明出处 1.UIView: 一个视图对象控制该区域的渲染,同时也控制内容的交互. 2.UIView的功能就是:展示.渲染.交互 3.UIView 和很多其他视图控件的默认tag值是0,所 ...

  7. PAT (Advanced Level) 1028. List Sorting (25)

    时间卡的比较死,用string会超时. #include<cstdio> #include<cstring> #include<cmath> #include< ...

  8. JS——实现短信验证码的倒计时功能(没有验证码,只有倒计时)

    1.功能描述 当用户想要获取验证码时,就点击 免费获取验证码 ,然后开始倒计时,倒计时期间按钮文字为剩余时间x秒,且不可按状态,倒计时结束后,按钮更改为点击重新发送. 2.分析 必须用到定时器.按钮点 ...

  9. SVG页面loading动态图

    https://github.com/SamHerbert/SVG-Loaders demo http://samherbert.net/svg-loaders/

  10. 全球主流8位MCU芯片详细解剖No.2:英飞凌 XC866 - 全文

    [导读] XC866是新型8位微控制器系列(XC800)的第一代系列产品,集成高性能8051核.片内FLASH及功能强大的外设集.此外,XC800系列产品内部集成的片 内振荡器和支持3.3V或5.0V ...