上篇文章我们讲述了eclipse安装hibernate插件的过程,这篇文章我们来做第一个HibernateDemo。

1)、hibernate的jar开发包的下载,官网下载地址:http://hibernate.org/orm/downloads/,解压后我们可以在hibernate-release-5.2.3.Final\lib\required文件夹下找到hibernate开发用到的jar包。

2)、新建一个Java Project项目,导入jar包(记得把MySQL的jar包也加进去),在src根目录下新建一个***.cfg.xml文件(安装插件成功后可以快速新建),然后我们进行文件配置,代码如下:

<session-factory>
<!-- 连接数据库的基本信息 -->
<property name="connection.username">root</property><!-- MySQL数据库的用户名 -->
<property name="connection.password">root</property><!-- MySQL数据库的密码 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property><!-- MySQL驱动 -->
<property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property><!--MySQL的URL,localhost(本地地址,可以省略)也可以改成远程服务器地址 --> <!-- 配置hibernate的基本信息 -->
<!-- hibernate所使用的基本方言 -->
<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property> <!-- 执行操作时是否在控制台打印 -->
<property name="show_sql">true</property> <!-- 是否对sql格式化 -->
<property name="format_sql">true</property> <!-- 指定自动生成数据表的策略 -->
<property name="hbm2ddl.auto">update</property>
<!-- 指定关联的.hbm.xml文件,这一步应该生成java beans后再配置 -->
<mapping resource="com/hibernateHello/News.hbm.xml"/> </session-factory>

3)、定义JavaBeans(对应你的数据表),

package com.hibernateHello;

import java.sql.Date;

public class News {
private Integer id;
private String author;
private String title;
private Date date; public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getAuthor() {
return author;
} public void setAuthor(String author) {
this.author = author;
} public String getTitle() {
return title;
} public void setTitle(String title) {
this.title = title;
} public Date getDate() {
return date;
} public void setDate(Date date) {
this.date = date;
} public News() {
// TODO Auto-generated constructor stub
} public News(String author, String title, Date date) {
// super();
this.author = author;
this.title = title;
this.date = date;
} }

4)、快捷生成JavaBeans对应的News.hbm.xml文件(也是插件提供),具体操作如下图所示。

生成的代码:

<hibernate-mapping>
<class name="com.hibernateHello.News" table="NEWS">
<!-- id 主键 -->
<id name="id" type="java.lang.Integer">
<column name="ID" />
<!-- 指定主键生成方式 native:使用数据库本地方式 -->
<generator class="native" />
</id>
<property name="author" type="java.lang.String">
<column name="AUTHOR" />
</property>
<property name="title" type="java.lang.String">
<column name="TITLE" />
</property>
<property name="date" type="java.sql.Date">
<column name="DATE" />
</property>
</class>
</hibernate-mapping>

5)、 ***.cfg.xml指定关联的**.hbm.xml文件(*千万不要忘记)

6)、通过JUnit测试,代码如下:

package com.hibernateHello;

import java.sql.Date;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.junit.After;
import org.junit.Before; public class Test {
private Configuration configuration;
private StandardServiceRegistry registry;
private SessionFactory sessionFactory;
private Session session;
private Transaction transaction; @Before
public void first() {
// 创建Configuration对象:对应hibernate的基本配置信息和对象关系映射信息
configuration = new Configuration().configure(); //创建一个对象StandardServiceRegistry,configure("你的***.cfg.xml"),默认为hibernate.cfg.xml
registry = new StandardServiceRegistryBuilder().configure().build(); // 创建会话工厂对象
sessionFactory = configuration.buildSessionFactory(registry); // 创建一个Session对象
session = sessionFactory.openSession(); // 开启事物
transaction = session.beginTransaction();
}

/*

* saveNews()添加数据

* getNews()和loadNews()查找数据
* updateNews()修改数据
* deleteNews()删除数据

*/

@org.junit.Test

public void saveNews() {
News news = new News("63va", "fe", new Date( new java.util.Date().getTime()));
session.save(news);
}
  
@org.junit.Test
public void getNews() {
News a1 = session.get(News.class, 1);
System.out.println(a1); } @org.junit.Test
public void loadNews() {
News a1 = session.load(News.class, 1);
System.out.println(a1); } @org.junit.Test
public void updateNews() {
News a1 = session.get(News.class, 2);
a1.setAuthor("ccc");
session.update(a1);
System.out.println(a1); } @org.junit.Test
public void deleteNews() {
News a1 = session.get(News.class, 4);
session.delete(a1);
// System.out.println(a1); } @After
public void finsh() {
// 提交事物
transaction.commit();
//关闭session
session.close();
// 关闭SessionFactory对象
sessionFactory.close();
} }

7)、运行效果如图所示:

hibernate学习-HibernateDemo的更多相关文章

  1. Hibernate学习之——搭建log4j日志环境

    昨天讲了Hibernate开发环境的搭建以及实现一个Hibernate的基础示例,但是你会发现运行输出只有sql语句,很多输出信息都看不见.这是因为用到的是slf4j-nop-1.6.1.jar的实现 ...

  2. Hibernate学习笔记(二)

    2016/4/22 23:19:44 Hibernate学习笔记(二) 1.1 Hibernate的持久化类状态 1.1.1 Hibernate的持久化类状态 持久化:就是一个实体类与数据库表建立了映 ...

  3. Hibernate学习笔记(一)

    2016/4/18 19:58:58 Hibernate学习笔记(一) 1.Hibernate框架的概述: 就是一个持久层的ORM框架. ORM:对象关系映射.将Java中实体对象与关系型数据库中表建 ...

  4. Hibernate 学习笔记一

    Hibernate 学习笔记一 今天学习了hibernate的一点入门知识,主要是配置domain对象和表的关系映射,hibernate的一些常用的配置,以及对应的一个向数据库插入数据的小例子.期间碰 ...

  5. Hibernate学习笔记-Hibernate HQL查询

    Session是持久层操作的基础,相当于JDBC中的Connection,通过Session会话来保存.更新.查找数据.session是Hibernate运作的中心,对象的生命周期.事务的管理.数据库 ...

  6. 我的hibernate学习记录(二)

    通过上一篇文章我的hibernate学习记录(一)基本上的入门了hibernate,但是,里面还有还多东西是通过迷迷糊糊的记忆,或者说copy直接弄进去的,所以这篇文章就需要对上篇的一些文件.对象进行 ...

  7. Hibernate学习(二)关系映射----基于外键的单向一对一

    事实上,单向1-1与N-1的实质是相同的,1-1是N-1的特例,单向1-1与N-1的映射配置也非常相似.只需要将原来的many-to-one元素增加unique="true"属性, ...

  8. Hibernate学习一:Hibernate注解CascadeType

    http://zy19982004.iteye.com/blog/1721846 ———————————————————————————————————————————————————————— Hi ...

  9. Hibernate学习---缓存机制

    前言:这些天学习效率比较慢,可能是手头的事情比较多,所以学习进度比较慢. 在之前的Hibernate学习中,我们无论是CURD,对单表查询还是检索优化,我们好像都离不开session,session我 ...

随机推荐

  1. .Net使用RabbitMQ详解

    序言 这里原来有一句话,触犯啦天条,被阉割!!!! 首先不去讨论我的日志组件怎么样.因为有些日志需要走网络,有的又不需要走网路,也是有性能与业务场景的多般变化在其中,就把他抛开,我们只谈消息Rabbi ...

  2. 【Win 10 应用开发】在后台进行多媒体转码

    前面,老周给大伙儿讲了如何运用 MediaTranscoder 类来完成多媒体.然而,你懂的,要是多媒体文件比较大,转码时间会更长,有可能用户不会一眭停在当前应用界面上,或许会切换到其他应用程序,甚至 ...

  3. EasyUI中那些不容易被发现的坑——EasyUI重复请求2次的问题

    问题控件:datagrid.combobox.所有能设置url属性的控件 问题版本:1.4.4.1.4.5(之前的版本没测) 问题如图: 重复请求2次,错误代码如图: 错误问题分析:html加载的时候 ...

  4. ORA 各种oraclesql错误

    ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...

  5. 排版紧凑情况下IOS 浏览器的文字部分选中问题

    一.需求 一个每一项都是图文混排的列表页,在需要对其中的某一部分文字进行选中copy的时候,IOS个二货每次都是直接选中了整个列表项,无论怎么操作它的选框都没有办法做到部分选中. 这是我本周遇到遇到的 ...

  6. Uploadify 结合 Web API 2 上传问题

    最近使用jQuery.Uploadify和Web API配合来做上传,碰到问题,还木有办法解决,记录一下: 环境:jQuery 1.10.2,Uploadify 3.2.1,SWFObject 2.2 ...

  7. GridView的使用(高度封装,不怎么灵活,repeat可替代)

    GridView的使用 首先,gridview是封装好的,直接在设计界面使用,基本不需要写代码: 一.绑定数据源 GridView最好与LinQDatasourse配合使用,相匹配绑定数据: 二.样式 ...

  8. [Oracle] Bulk Insert Data

    命名空间:Oracle.DataAccess.Client 组件:Oracle.DataAccess.dll(2.112.1.0) ODP.NET 版本:ODP.NET for .NET Framew ...

  9. .NET DateTime类型变量作为参数时设置默认值

    一个小的 Tips. .NET 中函数参数的默认值需要是编译时常量.如果参数是引用类型,可以设置Null,如果是值类型,可以设置相应的编译时常量,如整型可以用整数,但对于DateTime(结构体,值类 ...

  10. 【Java学习系列】第2课--Java语法及面向对象

    本文地址 分享提纲: 1. Java程序特点 1.1 基本语法 1.2 字符串 1.3 变量 1.4 Java数组 1.5 Java枚举 1.6 Java修饰符 1.7 Java编译制定在制定目录 2 ...