JDBC的优点
直接底层操作,提供了很简单、便捷的访问数据库的方法,跨平台性比较强。灵活性比较强,可以写很复杂的SQL语句。
JDBC的缺点
1).因为JAVA是面向对象的,JDBC没有做到使数据能够面向对象的编程,使程序员的思考仍停留在SQL语句上。
2).操作比较繁琐,很多代码需要重复写很多次。
3).如果遇到批量操作,频繁与数据库进行交互,容易造成效率的下降。
Jdbc是一个比较底层的东西,灵活写SQL语句
1)、注册驱动
2)、获得连接
3)、产生一个Statement
4)、进行操作
返回数据ResultSet
1)、new List对象
2)、把ResultSet数据放入List过程中
A a = new A();
a.setXXX(rs.getString("xxx"));
代码比较繁琐,纯的JDBC是没有缓存的。
l 模型不匹配(阻抗不匹配)
Java面向对象语言,对象模型,其主要概念有:继承、关联、多态等;数据库是关系模型,其主要概念有:表、主键、外键等。
l 解决办法
1使用JDBC手工转换。
2使用ORM(Object Relation Mapping对象关系映射)框架来解决。
对象模型中对象与对象之间的关联关系与关系模型中数据库表之间的关系无法一一对应。
对象模型中对象的继承关系在关系模型中无法直接表示。
对象模型中对象的等值性(equals)在关系模型中无法直接实现。
对象模型中有关联的对象之间的导航访问在关系模型中无法直接实现。
3hibernate
l Hibernate是一个开源ORM框架。
l ORM全称Object Relation Mapping,即对象关系映射。它是一种用来完成对象模型到关系模型的映射技术。就是把应用程序中的对象数据持久化到关系数据库的表的一种技术。
l 使用ORM( Object Relation Mapping )框架来解决。主流的ORM框架有JBoss公司的Hibernate、Oracle公司的TopLink、Apache组织的OJB、Sun公司的JDO。
l 简单的说:ORM能利用面向对象的思想开放基于关系型数据库的应用程序,它的主要工作是将对象数据保存到关系数据库的表中,以及将关系数据库表中数据读入到对象中。
4.安装配置
下载地址http://www.hibernate.org,这里举例使用的是3.3版本。解压获取必需类库文件。将下载目录/hibernate3.jar和/lib下的hibernate运行时必须的包加入classpath中:
需要使用的jar包以及jar包对应含义如下:
l 配置文件hibernate.cfg.xml和hibernate.properties,XML和properties两种,这两个文件的作用一样,提供一个即可,推荐XML格式,下载目录/etc下是示例配置文件,后者中列举的更详细,主要是与各种数据库连接模版。
l 可以在配置文件指定:
数据库的URL、用户名、密码、JDBC驱动类、方言等。
启动时Hibernate会在CLASSPATH里找这个配置文件。
l 映射文件(hbm.xml,对象模型和关系模型的映射)。在/eg目录下有完整的hibernate示例。
l 一个小例子步骤:
1).新建java或web项目,并加入相应的jar包及jdbc驱动。
2).创建持久化类(java bean)
3).准备数据库表
4).创建配置文件 hibernate.cfg.xml
5).创建映射文件 xxx.hbm.xml(与bean类在同一个包中)
6).创建测试文件(测试本项目)
5.细节分析
Hibernate.connection.url 表示要链接的数据库地址
Hibernate.connection.driver_class表示要链接的数据库的驱动类
Hibernate.connection.username 要连接的数据库的用户名
Hibernate.connection.password 要连接的数据库的密码
Hibernate.dialect 表示要使用的数据库的类型
org.hibernate.dialect.MySQL5Dialect mysql数据库
org.hibernate.dialect.Oracle9Dialect oracle数据库
org.hibernate.dialect.SQLServerDialect SQLServer数据库
hibernate.hbm2ddl.auto
validate:加载hibernate时验证创建表结构
update:加载hibernate时自动更新数据库结构,如果表存在不用创建,如果不存在就创建。
create:每一次加载hibernate时都创建表结构
create-drop:加载hibernate时创建,退出时删除
6.基本概念和增删改查
开发流程:
1、由Domain object -> mapping->db。(官方推荐)
2、由DB开始,用工具生成mapping和Domain object。(使用较多)
3、由映射文件开始。
Domain Object限制
1、默认的构造方法(必须的)。
2、有无意义的标示符id(主键)(可选)
3、非final的,对懒加载有影响(可选)
7案例:
Domain Java Object(User)
public class User {
private int id;
private String name;
private Date birthDay;
//getter setter…
}
l 对象关系映射文件:把面向对象中的实体类对象映射到数据库中的实体(表的记录),把实体类之间的关联关系也映射到数据库中多个表之间的相互关系中。这样,在Hibernate中对这些实体对象的操作就直接转换为对数据库表的记录的操作。
user.hbm.xml
<?xml version="1.0"?>
<hibernate-mapping package=“cn.itcast.domain">
<class name="User" table="user">
<id name="id">
<generator class="native"/>
</id>
<property name="name"/>
<property name="birthday”/>
</class>
</hibernate-mapping>
hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory name="foo">
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql:///hibernate</property>
<property name="connection.username">root</property>
<property name="connection.password">root</property>
<property name="dialect">org.hibernate.dialect.HSQLDialect</property>
<property name="show_sql">true</property>
<property name="hbm2ddl.auto">update</property>
<mapping resource="com/hbsi/domain/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
测试类 DemoTest.java
package com.hbsi.test;
import java.text.DateFormat;
import java.text.ParseException;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import com.hbsi.domain.User;
public class UserTest {
/**
* @param args
* @throws ParseException
*/
public static void main(String[] args) throws ParseException {
//给user类字段赋值
User user = new User();
user.setName("aa");
//user.setBirthday(new Date());
user.setBirthday(DateFormat.getDateInstance().parse("1992-01-01"));
//获取hibernate.cfg.xml的配置文件
Configuration cfg = new Configuration().configure();
//从session工厂中获取session,相当于jdbc中的connection
SessionFactory factory = cfg.buildSessionFactory();
Session session = factory.openSession();
session.beginTransaction();
session.save(user);
session.getTransaction().commit();
session.close();
}
}