【hibernate】赵雅智_hibernate 1 (hibernate引入,第一例)

hibernate第一例

新建java项目hibernate


在hibernate项目下,新建文件夹lib,并添加jar包



旁外话:添加jar包的两种方法及区别

  • 添加jar包的两种方法
    1. 从属性里添加jar包

    2. 新建文件夹,考本地jar包


  • 两者区别:
    • 第一种:记住添加路径,如果项目考走jar包就找不到了
    • 第二种:一般使用第二种,如果项目考走jar仍然可以找的到

新建数据库hibernate


新建表user


新建domain包,封装类


User.java

package www.hbsi.com.domain;

import java.sql.Date;

public class User {
	private int id;
	private String name;
	private Date birthday;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Date getBirthday() {
		return birthday;
	}
	public void setBirthday(Date birthday) {
		this.birthday = birthday;
	}
	@Override
	public String toString() {
		return "User [birthday=" + birthday + ", id=" + id + ", name=" + name
				+ "]";
	}
}
创建配置文件

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工厂 -->
	<session-factory>
		<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">123456</property>
        <!-- 方言,连接的哪个数据库 -->
	    <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
		<!-- 执行的时候是否输出sql句 -->
		<property name="show_sql">true</property>
		<!-- 数据定义语言 -->
		<property name="hbm2ddl.auto">update</property>
	</session-factory>
</hibernate-configuration>

持久化类的映射文件


User.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
      "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">


<hibernate-mapping package="com.hbsi.domain">
	<!-- 主键 -->
    <class name="User" >
        <id name="id">
            <generator class="increment" />
        </id>
        <!-- 属性 -->
        <property name="name" />
        <property name="birthday" />
    </class>

    

</hibernate-mapping>

让hibernate.cfg.xml知道持久化类,修改hibernate.cfg.xml

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工厂 -->
	<session-factory>
		<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">123456</property>
        <!-- 方言,连接的哪个数据库 -->
	    <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
		<!-- 执行的时候是否输出sql句 -->
		<property name="show_sql">true</property>
		<!-- 数据定义语言 -->
		<property name="hbm2ddl.auto">update</property>
		<!-- 加载持久化类文件 -->
		<mapping resource="www/hbsi/com/domain/User.hbm.xml"/>
	
	</session-factory>
</hibernate-configuration>


做一个测试类



Demo1.java

package www.hbsi.com.demo;
import java.util.Date;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import www.hbsi.com.domain.User;

public class Demo1 {
	public static void main(String args[]){
		User user = new User();
		user.setName("Nacy");
		user.setBirthday(new Date());
		
		//新建一个配置对象,通过此对象加载hibernate.cfg.xml信息
		Configuration cfg = new Configuration().configure();
		
		//创建session工厂
		SessionFactory sessionFactory = cfg.buildSessionFactory();
		//得到session对象  相当于JDBC的Connection
		Session session = sessionFactory.openSession();
		
		//hibernate下要开启事务进行保存
		session.beginTransaction();
		//保存
		session.save(user);
		//提交事务
		session.getTransaction().commit();
		//关闭事务
		session.close();
	}
}





详解Hibernate.cfg.xml中的<property name="hbm2ddl.auto">update</property>

update作用: 

  1. 程序代码映射关系不符合表结构,更新表结构
  2. 如果没有表,新建一个表
【update作用2实例】

删除数据库hibernate中的user表



运行上面Demo1代码




字符串转成date类型:


create作用:

  • 新建,一执行就创建,表中只能保存一条,其他记录保存不下来

create-drop作用:

  • 新建,创建完之后就删除

一般都配置update

详解Hibernate.cfg.xml中的<property name="show_sql">true</property>
显不显示sql语句,如果不为true,控制台不输出sql语句

开启事务与关闭事务



增删改都需要开启事务,查询就不需要开启了


回顾

  • JDBC数据库连接
    • JDBC的优点
      • 直接底层操作,提供了很简单、便捷的访问数据库的方法,跨平台性比较强。灵活性比较强,可以写很复杂的SQL语句。
    • JDBC的缺点
      1. 因为JAVA是面向对象的,JDBC没有做到使数据能够面向对象的编程,使程序员的思考仍停留在SQL语句上。
      2. 操作比较繁琐,很多代码需要重复写很多次。
      3. 如果遇到批量操作,频繁与数据库进行交互,容易造成效率的下降。 

引入

  • 模型不匹配(阻抗不匹配)
    • Java面向对象语言,对象模型,其主要概念有:继承、关联、多态等;数据库是关系模型,其主要概念有:表、主键、外键等。
  • 解决办法
    1. 使用JDBC手工转换。
    2. 使用ORM(Object Relation Mapping对象关系映射)框架来解决。
  • Hibernate是一个开源ORM框架。
  • ORM全称Object Relation Mapping,即对象关系映射。它是一种用来完成对象模型到关系模型的映射技术。
    • 就是把应用程序中的对象数据持久化到关系数据库的表的一种技术。
  • 使用ORM( Object Relation Mapping )框架来解决。主流的ORM框架有JBoss公司的Hibernate、Oracle公司的TopLink、Apache组织的OJB、Sun公司的JDO。
  • 简单的说:ORM能利用面向对象的思想开放基于关系型数据库的应用程序,它的主要工作是将对象数据保存到关系数据库的表中,以及将关系数据库表中数据读入到对象中。

安装配置

  • 下载地址http://www.hibernate.org,使用3.3版本。
  • 解压获取必需类库文件
  • 将下载目录/hibernate3.jar和/lib下的hibernate运行时必须的包加入classpath中:
  • 配置文件hibernate.cfg.xml和hibernate.properties,XML和properties两种,这两个文件的作用一样,提供一个即可,推荐XML格式,下载目录/etc下是示例配置文件。
  • 可以在配置文件指定:
  • 数据库的URL、用户名、密码、JDBC驱动类、方言等。
  • 启动时Hibernate会在CLASSPATH里找这个配置文件。
  • 映射文件(hbm.xml,对象模型和关系模型的映射)。在/eg目录下有完整的hibernate示例。 

快速开始小例子

步骤:

  1. 新建java项目,并加入相应的jar包,及jdbc驱动。
  2. 创建持久化类
  3. 准备数据库表
  4. 创建配置文件 hibernate.cfg.xml
  5. 创建映射文件 xxx.hbm.xml
  6. 创建测试文件

  • 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时创建,退出时删除

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值