首页 技术 正文
技术 2022年11月14日
0 收藏 460 点赞 5,090 浏览 1930 个字

参考: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)、根据项目需求,封装成某种特定数据类型

七、单值封装

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,498
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,911
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,745
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,502
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,141
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,304