学习Hibernate in Action读书笔记(1)

转载 2004年08月24日 15:05:00

http://dev.csdn.net/article/33/33936.shtm

让我们还是以这个经久不衰的例子"Hello World"开始:)

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

1.      Message.java: 一个简单的持久类

package hello;

 

public class Message {

private Long id;   //说明

private String text;

 private Message nextMessage;

 private Message() {}

 

public Message(String text) {

this.text = text;

}

 

public Long getId() {

return id;

}

 

private void setId(Long id) {

this.id = id;

}

 

public String getText() {

return text;

}

 

public void setText(String text) {

this.text = text;

}

 

public Message getNextMessage() {

return nextMessage;

}

 

public void setNextMessage(Message nextMessage) {

this.nextMessage = nextMessage;

}

}

 

 

 

说明: ID标识符 (identifier) ,它允许应用去访问数据库以一个唯一的标识,这个标识也就是持久类的主键值。如果一个Message对象有两个实例,它们拥有同一个标识,那么代表他们访问的是数据库的同一个数据。在这里我们选择了Long做这个标识的数据类型,但是这不是必须的。因为Hibernate允许这个identifier为任何的数据类型。

 

 

2.         保存数据信息到数据库:

 

Session session = getSessionFactory().openSession();

Transaction tx = session.beginTransaction();

Message message = new Message("Hello World");

session.save(message);

tx.commit();

session.close();

 

在这段代码中,我们引用了HibernateSessionTransaction接口。这段代码的执行,就好像我们做了下面这段SQL所做的事:

insert into MESSAGES (MESSAGE_ID, MESSAGE_TEXT, NEXT_MESSAGE_ID)

values (1, 'Hello World', null)

 

注:这个例子中,我们假设数据中已经存在MESSAGES这张表了。

 

3.         从数据库中读出信息并打印它们

 

Session newSession = getSessionFactory().openSession();

Transaction newTransaction = newSession.beginTransaction();

List messages =

newSession.find("from Message as m order by m.text asc");

System.out.println( messages.size() + " message(s) found:" );

for ( Iterator iter = messages.iterator(); iter.hasNext(); ) {

Message message = (Message) iter.next();

System.out.println( message.getText() );

}

newTransaction.commit();

newSession.close();

 

这段代码中,大家看到了“from Message as m order by m.text asc”,这是Hibernate自带的面向对象查询语言Hibernate Query Language (HQL).那么翻译一下这句话,就是下面这个SQL了:

select m.MESSAGE_ID, m.MESSAGE_TEXT, m.NEXT_MESSAGE_ID

from MESSAGES m

order by m.MESSAGE_TEXT asc

 

输出结果:

1 message(s) found:

Hello World

 

 

4.         简单的XML映射文件

 

<?xml version="1.0"?>

"-//Hibernate/Hibernate Mapping DTD//EN"

"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

<?xml:namespace prefix = class

name="hello.Message"

table="MESSAGES">

<?xml:namespace prefix = id

name="id"

column="MESSAGE_ID">

 

<?xml:namespace prefix = property

name="text"

column="MESSAGE_TEXT"/>

<?xml:namespace prefix = many-to-one

name="nextMessage"

cascade="all"

column="NEXT_MESSAGE_ID"/>

 

这个映射文件告诉HibernateMessage这个类是持久化的MESSAGES这张数据库表,identifier属性对应的是表中的MESSAGE_ID字段,text属性对应的是MESSAGE_TEXT字段,nextMessage是一个多对一的关联,对应的是NEXT_MESSAGE_ID字段。

上面这个文件可以手工编写,也可以借助第三方工具生成。

 

 

5.         更新一条信息

下面让我们修改一下刚才存到数据库里面的第一条信息。

 

Session session = getSessionFactory().openSession();

Transaction tx = session.beginTransaction();

// 1 is the generated id of the first message

Message message =

(Message) session.load( Message.class, new Long(1) );

message.setText("Greetings Earthling");

Message nextMessage = new Message("Take me to your leader (please)");

message.setNextMessage( nextMessage );

tx.commit();

session.close();

 

这段代码等同以下三个SQL语句所要实现的东西:

select m.MESSAGE_ID, m.MESSAGE_TEXT, m.NEXT_MESSAGE_ID

from MESSAGES m

where m.MESSAGE_ID = 1

 

insert into MESSAGES (MESSAGE_ID, MESSAGE_TEXT, NEXT_MESSAGE_ID)

values (2, 'Take me to your leader (please)', null)

update MESSAGES

 

set MESSAGE_TEXT = 'Greetings Earthling', NEXT_MESSAGE_ID = 2

where MESSAGE_ID = 1

 

 

再次运行“Hello World”,输入信息如下:

 

 

2 message(s) found:

Greetings Earthling

Take me to your leader (please)

 

 

*补充,在Hibernate中最核心的五个接口:

Session接口:这是Hibernate中一个主要的接口,Session接口的建立和消毁都是轻量级并且耗费资源很少的。这一点很重要,因为在我们的应用,我们每时每刻都在做着Sessioncreatedistroy工作。它不是线程安全的,原则上它应该设计成一个时间只有一个Session才对。Session可以加载一个与一个工作流相关的对象,它可以监测着这个对象的变化,它被称之为持久对象的管理器,当我们要对数据对象进行编辑操作时,就要调用它了。

 

SessionFactory接口:我们请求一个Session实例,就是从SessionFactory中取得了。当然SessionFactory就不是个轻量级的东西了,它被多个应用的线程所共享。如果你通过Hibernate访问多个数据库,就要为每一个数据库建立一个SessionFactory。在Hibernate的运行时,SessionFactory缓存了SQL段和其它的中介映射数据。它也保持one unit of work正在读取的数据和将来可能被用到的数据。

 

Configuration接口:Configuration用于指定一个应用所使用的映射文件的地址和Hibernate指定的属性文件,然后建立一个SessionFactory

 

Transaction接口:

 

Query and Criteria接口:

 

 

 (未完)

 


作者Blog:http://blog.csdn.net/Strawberry79/
相关文章

Hibernate实战_笔记10

使用Hibernate EntityManager Hibernate EntityManager是围绕提供JPA编程接口的Hibernate Core的一个包装,支持JPA实体实例的生命周期,并允许...
  • com185272358
  • com185272358
  • 2014年03月08日 13:27
  • 1206

Spring In Action 4 学习笔记(一)Spring概览

Spring的核心概念就是DI和AOP,是Spring实现所有复杂华丽框架的基石。 相对于EJB等重型框架,Spring更加轻量化,可以强化普通的POJO对象。 1、简化JAVA开发 为了尽可能...
  • BenChale
  • BenChale
  • 2016年05月20日 16:39
  • 7971

《Java JDK8学习笔记》读书笔记(4)

第4章 认识对象 学习目标  区分基本类型与对象类型  了解对象与引用的关系  从打包器认识对象  以对象观点看待数组  认识字符串的特性...
  • mouyong
  • mouyong
  • 2016年04月18日 20:10
  • 4399

《Spring In Action》 读书笔记(1) -- bean装配

这是我第一本java类的书,在学SSH的时候,感觉spring是最没用的,然而现在实习快一年了,现在才发现spring的精妙,决定看本书来更了解下spring,这两天学习bean装配,别看内容简单,其...
  • lovejj1994
  • lovejj1994
  • 2016年06月15日 10:55
  • 275

读书笔记-HBase in Action-第三部分应用-(1)OpenTSDB

OpenTSDB是基于HBase的开源监控系统,可以支持上万规模集群监控和上亿数据点采集。其中TSDB代表Time Series Database,OpenTSDB在时间序列数据的存储和查询上都做了相...
  • cargogo
  • cargogo
  • 2014年07月30日 16:21
  • 1858

Spring Integration In action读书笔记 Part1 - 背景介绍

1. Spring Integration介绍1.1 Spring Integration架构1.2 Spring Integration 对企业集成模式的支持1.3 企业集成模式契合控制反转1.4 ...
  • littlemice
  • littlemice
  • 2015年04月11日 16:59
  • 562

Cpp_Concurrency_In_Action-读书笔记(day 1)

2.1 线程管理的基础 每个程序至少有一个线程:执行main()函数的线程,其余线程有其各自的入口函数。线程与原始线程(以main()为入口函数的线程)同时运行。如同main()函数执行完会退出一样...
  • m0_38132571
  • m0_38132571
  • 2017年07月09日 17:25
  • 87

《Maven in Action》读书笔记(最全版,DIY)

  • 2012年02月24日 12:22
  • 3.58MB
  • 下载

JAVA 8 In Action 读书笔记(源码)[已更新]

  • 2017年11月23日 13:46
  • 102KB
  • 下载

JAVA 8 In Action 读书笔记(源码)

  • 2017年11月23日 12:31
  • 100KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:学习Hibernate in Action读书笔记(1)
举报原因:
原因补充:

(最多只允许输入30个字)