Hibernate之Hibernate环境搭建

一、Hibernate环境搭建的步骤

1.添加Hibernate && SQLServer 的Jar
  antlr-2.7.7.jar
  dom4j-1.6.1.jar
  hibernate-commons-annotations-4.0.5.Final.jar
  hibernate-core-4.3.11.Final.jar
  hibernate-jpa-2.1-api-1.0.0.Final.jar
  jandex-1.1.0.Final.jar
  javassist-3.18.1-GA.jar
  jboss-logging-3.1.3.GA.jar
  jboss-logging-annotations-1.2.0.Beta1.jar
  jboss-transaction-api_1.2_spec-1.0.0.Final.jar

  sqljdbc4.jar

2.创建JavaBean类:User.java

 package cn.com.zfc.hibernate.entities;

 /**
*
* @title User
* @describe Hibernate 的 POJO
* @author 张富昌
* @date 2017年4月7日下午10:47:27
*/
public class User {
  private Integer id;
  private String userName;
  private String userDesc;   public User() {
    super();
  }   public User(String userName, String userDesc) {
    super();
    this.userName = userName;
    this.userDesc = userDesc;
  }   public Integer getId() {
    return id;
  }   public void setId(Integer id) {
    this.id = id;
  }   public String getUserName() {
    return userName;
  }   public void setUserName(String userName) {
    this.userName = userName;
  }   public String getUserDesc() {
    return userDesc;
  }   public void setUserDesc(String userDesc) {
    this.userDesc = userDesc;
  }   @Override
  public String toString() {
    return "User [id=" + id + ", userName=" + userName + ", userDesc=" + userDesc + "]";
  }
}

3.使用Xxx.hbm.xml 映射文件映射JavaBean属性到数据库表之间的映射关系: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">
<!-- Generated 2017-3-19 13:53:52 by Hibernate Tools 3.5.0.Final -->
<!-- 一般写 package,简化全类名 -->
<hibernate-mapping package="cn.com.zfc.hibernate.entities">
  <class name="User" table="USERS">
    <!-- 映射主键,id:属性,column:字段 -->
    <id name="id" type="java.lang.Integer">
      <column name="ID" />
      <!-- 主键生成策略 -->
      <generator class="native" />
    </id>
    <!-- 映射普通字段,property:属性,column:字段 -->
    <property name="userName" type="java.lang.String">
      <column name="USER_NAME" />
    </property>     <property name="userDesc" type="java.lang.String">
      <column name="USER_DESC" />
    </property>
  </class>
</hibernate-mapping>

4.在hibernate.cfg.xml Hibernate配置文件中配置Hibernate 数据源及相关属性:在hibernate.cfg.xml

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
  <session-factory>
    <!-- Hibernate 的基本配置 -->     <!-- 数据源信息配置 -->
    <!-- 数据库用户名 -->
    <property name="hibernate.connection.username">sa</property>
    <!-- 数据库密码 -->
    <property name="hibernate.connection.password">123456</property>
    <!-- 数据库驱动宝 -->
    <property name="hibernate.connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
    <!-- 不指定数据库名称,可以在映射文件中指定数据库名称 -->
    <property name="hibernate.connection.url">jdbc:sqlserver://localhost:1433;DatabaseName=hibernate-01</property>     <!-- 指定在控制台输出 SQL 语句,便于调试 -->
    <property name="show_sql">true</property>
    <!-- 格式化 SQL 语句 -->
    <property name="format_sql">true</property>
    <!-- 指定数据库生成策略 -->
    <property name="hbm2ddl.auto">update</property>
    <!-- 配置数据库方言 -->
    <property name="dialect">org.hibernate.dialect.SQLServerDialect</property>     <!-- 注册 Hibernate 映射文件 -->
    <mapping resource="cn/com/zfc/hibernate/entities/User.hbm.xml" />
  </session-factory>
</hibernate-configuration>

5.使用Hibernate ORM框架完成对JavaBean对象的操作

  ①创建Configuration对象
    Configuration configuration = new Configuration().configure();
  ②创建SessionFactory 工厂类
    ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build();
    SessionFactory sessionFactory = configuration.buildSessionFactory(serviceRegistry);
  ③创建Session对象
    Session session = sessionFactory.openSession();
  ④开启事物 Transaction(查询不需要事务)
    Transaction transaction = session.beginTransaction();
  ⑤执行业务******
    CRUD操作
  ⑥提交事物
    transaction.commit();
  ⑦关闭会话
    session.close();
  ⑧关闭 SessionFactory
    sessionFactory.close();

 6.数据库:hibernate-01

数据表:users

二、JUNIT 单元测试初识

1.单元测试的基本概念

2.使用Junit 搭建Hibernate 测试环境

3.@Test @Before @After

4.Hibernate 环境的测试:TestHibernate.java

 package cn.com.zfc.hibernate.test;

 import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.junit.After;
import org.junit.Before;
import org.junit.Test; import cn.com.zfc.hibernate.entities.User; /**
*
* @title TestHibernate
* @describe 测试 Hibernate 的环境
* @author 张富昌
* @date 2017年4月7日下午10:47:05
*/
public class TestHibernate {   private Configuration configuration = null;
  private SessionFactory sessionFactory = null;
  private Session session = null;
  private Transaction transaction;   @Before
  public void init() {
    configuration = new Configuration().configure();
    ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build();
    sessionFactory = configuration.buildSessionFactory(serviceRegistry);
    session = sessionFactory.openSession();
    transaction = session.beginTransaction();
  }   @After
  public void destory() {
    transaction.commit();
    session.close();
    sessionFactory.close();
  }   // 添加
  @Test
  public void testSave() {
    User user = new User("UU-1", "爱生活,爱编程");
    session.save(user);
  }   // 立即加载
  @Test
  public void testGet() {
    User user = (User) session.get(User.class, 1);
    System.out.println("user:" + user);
  }   // 延迟加载:当数据真正使用时在开始加载
  @Test
  public void testLoad() {
    User user = (User) session.load(User.class, 1);
    System.out.println("user:" + user);
  }   // 删除
  @Test
  public void testDelete() {
    User user = (User) session.load(User.class, 4);
    session.delete(user);
  }   // 修改
  @Test
  public void testUpdate() {
    User user = (User) session.load(User.class, 1);
    user.setUserDesc("我是修改过的东西");
    session.update(user);
  }   @Test
  public void dataSource() {
  } }

Hibernate之Hibernate环境搭建的更多相关文章

  1. 最新版ssh hibernate spring struts2环境搭建

    最新版ssh hibernate spring struts2环境搭建 最新版spring Framework下载地址:spring4.0.0RELEASE环境搭建 http://repo.sprin ...

  2. Hibernate 系列 02 - Hibernate介绍及其环境搭建

    引导目录: Hibernate 系列教程 目录 昨晚喝多了,下午刚清醒,继续搞Hibernate.走起. 觉得还行的话,记得点赞哈,给我这个渣渣点学习的动力.有错误的话也请指出,省的我在错误上走了不归 ...

  3. Hibernate 介绍及其 环境搭建

    介绍 数据持久化概念 数据持久化是将内存中的数据模型转换为存储模型,以及将存储模型转换为内存中的数据模型的统称.例如:文件的存储.数据的读取等都是数据持久化操作.数据模型可以是任何数据结构或对象模型, ...

  4. hibernate之helloword(环境搭建)

    环境搭建 hibernate.cfg.xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE ...

  5. Hibernate(一)——采用Hibernate框架开发环境搭建

    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员充分使用对象编程思维来操作数据库.HIbernate的移植性很好,它可以应用于任何JDB ...

  6. hibernate介绍及环境搭建

    1.前言 hibernate与mybatis的位置一样,都是属于DAO层的框架,代替我们原来的JDBC操作数据库,属于ORM(object relationg mapping. 对象关系映射)框架.O ...

  7. Hibernate学习笔记--环境搭建及运行

    1.hibernate开发包下载 http://sourceforge.net/projects/hibernate/files/ 如果不能访问请用代理http://dongtaiwang.com/l ...

  8. Hibernate之环境搭建

    开始之前,我想先理清一个概念,即ORM是什么? ORM介绍 全称:Object/Relation Mapping,即对象/关系映射. ORM也可以理解为一种规范,具体的ORM框架可作为应用程序和数据库 ...

  9. Hibernate学习之——Hibernate环境搭建

    之前在写关于安卓闹钟的教程,写了一半就没后一半了,其实自己也没做好,在校外实习,校内毕业实习又有任务,只能先放放了,等毕业实习结束之后,在继续安卓闹钟开发之旅,相信这个时间不会很久的.现在毕业实习用到 ...

  10. Hibernate之环境搭建及demo

    ORM概念 ORM即Object/Relation Mapping, 对象/关系数据库映射.ORM是一种规范,完成面向对象编程语言到关系数据库之间的映射.J2EE中的JPA就是一种ORM规范. ORM ...

随机推荐

  1. Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A

    问题: 当我们打开数据库,即use dbname时,要预读数据库信息,当使用-A参数时,就不预读数据库信息. 解决方法:mysql -hhostname -uusername -ppassword - ...

  2. fonts.googleapis.com 字体报错问题解决。

    更多内容推荐微信公众号,欢迎关注: 无法加载这些字体是因为,google的网站在国内无法访问造成的.在AdminLTE.css 和AdminLte.less中有如下内容: @import url(ht ...

  3. python基础——python解析yaml类型文件

    一.yaml介绍 yaml全称Yet Another Markup Language(另一种标记语言).采用yaml作为配置文件,文件看起来直观.简洁.方便理解.yaml文件可以解析字典.列表和一些基 ...

  4. oracle07

    1. 索引INDEX  1.1. 索引的概念特性和作用 概念: 简单的说,相当于一本书的目录.(数据库中的索引相当于字典的目录(索引)),它的作用就是提升查询效率. 特性: l 一种独立于表的模式(数 ...

  5. node.js、git、bootstrap等安装配置

    纯记录 一,安装node.js 1 官方网址 http://nodejs.org/  点击install 下载node-v0.10.22-x86.msi 2 安装,修改安装目录到d盘,一路next,无 ...

  6. Dream------scala--类的属性和对象私有字段实战详解

    Scala类的属性和对象私有字段实战详解 一.类的属性 scala类的属性跟java有比较大的不同,需要注意的是对象的私有(private)字段 1.私有字段:字段必须初始化(当然即使不是私有字段也要 ...

  7. style一张图--openlayers

  8. echarts 移动端地图数据可视化开发教程

    如上效果图: 以下未代码: <!doctype html> <html lang="en">   <head> <meta charset ...

  9. No.13 selenium for python 单选框和复选框

    单选框 radio 点击图标,可以获取HTML中定位. 使用普通的ID定位就可以了 定位到指定元素,然后使用clicd选中即可 复选框 checkbox 勾选单个框,跟单选框一样,定位后点击就可以了 ...

  10. Centos之文件搜索命令locate

    locate命令 locate 文件名 在后台数据库中按文件名搜索,搜索速度更快 /var/lib/mlocate #locate命令所搜索的后台数据库 updatedb 更新数据库 locate搜索 ...