- 浏览: 914804 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (537)
- Java SE (114)
- Struts (18)
- Hibernate (25)
- Spring (3)
- Page_Tech (41)
- Others (87)
- Database (29)
- Server (24)
- OpenSource_Tools (15)
- IDE_Tool (22)
- Algorithm (28)
- Interview (22)
- Test (28)
- Hardware (1)
- Mainframe (25)
- Web application (4)
- Linux (3)
- PHP (17)
- Android (1)
- Perl (6)
- ubuntu (1)
- Java EE (9)
- Web Analysis (5)
- Node.js (2)
- javascript (2)
最新评论
-
一键注册:
request.getRequestURL()和request.getRequestURI() -
SuperCustomer:
...
SED的暂存空间和模式空间 -
juyo_ch:
讲得挺好理解的,学习了
java 死锁及解决 -
chinaalex:
最后一题答案正确,但是分析有误.按照如下过程,上一行为瓶,下一 ...
zz智力题 -
liaowuxukong:
多谢博主啦,弱弱的了解了一点。
C++/Java 实现多态的方法(C++)
准备找工作,重新整理一下Hibernate,今天做了集合映射的测试,以前是使用MyEclipse自动生成,今天开始手动配置。
在手动配置的过程中还真是出了不少问题,少包,漏写这漏写那,不过还好,很快都把错误排除了。
其中这个问题记录一下:
No CurrentSessionContext configured!" 异常
之前都是getSession()或用spring整合做web,所以没有注意到单独使用hibernate时如果用SessionFactory.getCurrentSession()要配置上这个:
<property name="current_session_context_class">thread</property>
为当前Session指定一个策略。
Set集合测试
build.xml
Hibernate.cfg.xml
Customer.java
Img.java
//manager
//测试类
数据库中添加aaa、bbb字段,把重复的项去了。
List映射
将Customer.java中img注释改成如下
在Img.java中添加一个索引字段ind
OK其它都和Set一样
数据库中添加aaa、bbb、aaa字段。充许添加重复项。
Map映射
和Set差不多,只是加了一个index项作为map的key
Customer.java改动
Img.java
测试:
数据库同样只添加了img4、img5,去除了重复项。
在手动配置的过程中还真是出了不少问题,少包,漏写这漏写那,不过还好,很快都把错误排除了。
其中这个问题记录一下:
No CurrentSessionContext configured!" 异常
之前都是getSession()或用spring整合做web,所以没有注意到单独使用hibernate时如果用SessionFactory.getCurrentSession()要配置上这个:
<property name="current_session_context_class">thread</property>
为当前Session指定一个策略。
Set集合测试
build.xml
- <?xml version="1.0"?>
- <project default="main" basedir=".">
- <property name="src" value="src"/>
- <property name="bin" value="bin"/>
- <property name="lib" value="lib"/>
- <property name="xdoclet.home" value="D:/xdoclet-plugins-1.0.3"/>
- <path id="xdoclet.task.classpath">
- <fileset dir="${xdoclet.home}/lib">
- <include name="**/*.jar"/>
- </fileset>
- <fileset dir="${xdoclet.home}/plugins">
- <include name="**/*.jar"/>
- </fileset>
- </path>
- <taskdef
- name="xdoclet"
- classname="org.xdoclet.ant.XDocletTask"
- classpathref="xdoclet.task.classpath"
- />
- <target name="生成配置文件">
- <xdoclet>
- <fileset dir="${src}/pojo/">
- <include name="**/*.java"/>
- </fileset>
- <component
- classname="org.xdoclet.plugin.hibernate.HibernateConfigPlugin"
- destdir="${src}"
- version="3.0"
- hbm2ddlauto="update"
- jdbcurl="jdbc:mysql://localhost/hib"
- jdbcdriver="com.mysql.jdbc.Driver"
- jdbcusername="root"
- jdbcpassword="520"
- dialect="org.hibernate.dialect.MySQLDialect"
- showsql="true"
- />
- </xdoclet>
- </target>
- <target name="生成映射文件">
- <xdoclet>
- <fileset dir="${src}/pojo">
- <include name="**/*.java"/>
- </fileset>
- <component
- classname="org.xdoclet.plugin.hibernate.HibernateMappingPlugin"
- version="3.0"
- destdir="${src}"
- />
- </xdoclet>
- </target>
- </project>
<?xml version="1.0"?>
<project default="main" basedir=".">
<property name="src" value="src"/>
<property name="bin" value="bin"/>
<property name="lib" value="lib"/>
<property name="xdoclet.home" value="D:/xdoclet-plugins-1.0.3"/>
<path id="xdoclet.task.classpath">
<fileset dir="${xdoclet.home}/lib">
<include name="**/*.jar"/>
</fileset>
<fileset dir="${xdoclet.home}/plugins">
<include name="**/*.jar"/>
</fileset>
</path>
<taskdef
name="xdoclet"
classname="org.xdoclet.ant.XDocletTask"
classpathref="xdoclet.task.classpath"
/>
<target name="生成配置文件">
<xdoclet>
<fileset dir="${src}/pojo/">
<include name="**/*.java"/>
</fileset>
<component
classname="org.xdoclet.plugin.hibernate.HibernateConfigPlugin"
destdir="${src}"
version="3.0"
hbm2ddlauto="update"
jdbcurl="jdbc:mysql://localhost/hib"
jdbcdriver="com.mysql.jdbc.Driver"
jdbcusername="root"
jdbcpassword="520"
dialect="org.hibernate.dialect.MySQLDialect"
showsql="true"
/>
</xdoclet>
</target>
<target name="生成映射文件">
<xdoclet>
<fileset dir="${src}/pojo">
<include name="**/*.java"/>
</fileset>
<component
classname="org.xdoclet.plugin.hibernate.HibernateMappingPlugin"
version="3.0"
destdir="${src}"
/>
</xdoclet>
</target>
</project>
Hibernate.cfg.xml
- <?xml version="1.0" encoding="ISO-8859-1"?>
- <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
- <hibernate-configuration>
- <session-factory>
- <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
- <property name="hibernate.connection.url">jdbc:mysql://localhost/hib</property>
- <property name="hibernate.connection.username">root</property>
- <property name="hibernate.connection.password">520</property>
- <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
- <property name="hibernate.show_sql">true</property>
- <property name="hibernate.hbm2ddl.auto">update</property>
- <property name="current_session_context_class">thread</property>
- <mapping resource="pojo/Customer.hbm.xml"/>
- <mapping resource="pojo/Img.hbm.xml"/>
- </session-factory>
- </hibernate-configuration>
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost/hib</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">520</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<property name="current_session_context_class">thread</property>
<mapping resource="pojo/Customer.hbm.xml"/>
<mapping resource="pojo/Img.hbm.xml"/>
</session-factory>
</hibernate-configuration>
Customer.java
- package pojo;
- import java.util.Date;
- import java.util.HashSet;
- import java.util.Set;
- /**
- * @author Administrator
- *@hibernate.class
- * table=T_Customer
- */
- public class Customer {
- /**
- * @hibernate.id
- * column="cid"
- * generator-class="native"
- */
- private int id;
- /**
- * @hibernate.property
- * column="name"
- */
- private String name;
- /**
- * @hibernate.property
- * column="data"
- */
- private Date data;
- /**
- * @hibernate.property
- * column="address"
- */
- private String address;
- /**
- * @hibernate.set
- * table="T_Img"
- * @hibernate.key
- * column="cid"
- * @hibernate.element
- * column="name"
- * type="string"
- */
- private Set img;
- }
package pojo;
import java.util.Date;
import java.util.HashSet;
import java.util.Set;
/**
* @author Administrator
*@hibernate.class
* table=T_Customer
*/
public class Customer {
/**
* @hibernate.id
* column="cid"
* generator-class="native"
*/
private int id;
/**
* @hibernate.property
* column="name"
*/
private String name;
/**
* @hibernate.property
* column="data"
*/
private Date data;
/**
* @hibernate.property
* column="address"
*/
private String address;
/**
* @hibernate.set
* table="T_Img"
* @hibernate.key
* column="cid"
* @hibernate.element
* column="name"
* type="string"
*/
private Set img;
}
Img.java
- package pojo;
- /**
- *
- * @author Administrator
- *@hibernate.class
- * table="T_Img"
- */
- public class Img {
- /**
- * @hibernate.id
- * column="img_id"
- * generator-class="native"
- */
- private int id;
- /**
- * @hibernate.property
- * column="name"
- */
- private String name;
- }
package pojo;
/**
*
* @author Administrator
*@hibernate.class
* table="T_Img"
*/
public class Img {
/**
* @hibernate.id
* column="img_id"
* generator-class="native"
*/
private int id;
/**
* @hibernate.property
* column="name"
*/
private String name;
}
//manager
- public class CustomerManagerImpl extends BaseManager implements CustomerManager {
- public void addCustomer(Customer customer) {
- Session session=getSession();
- Transaction tr = session.beginTransaction();
- session.save(customer);
- tr.commit();
- closeSession(session);
- }
- public void delCustomer(int id) {
- Session session=getSession();
- Transaction tr = session.beginTransaction();
- Customer customer=(Customer)session.load(Customer.class, id);
- session.delete(customer);
- tr.commit();
- closeSession(session);
- }
- }
public class CustomerManagerImpl extends BaseManager implements CustomerManager {
public void addCustomer(Customer customer) {
Session session=getSession();
Transaction tr = session.beginTransaction();
session.save(customer);
tr.commit();
closeSession(session);
}
public void delCustomer(int id) {
Session session=getSession();
Transaction tr = session.beginTransaction();
Customer customer=(Customer)session.load(Customer.class, id);
session.delete(customer);
tr.commit();
closeSession(session);
}
}
//测试类
- public class CustomerManagerImplTest extends TestCase {
- CustomerManagerImpl m=new CustomerManagerImpl();
- public void testAddCustomer() {
- Customer c=new Customer();
- c.setName("死亡骑士");
- c.setAddress("五一九路");
- c.setData(new Date());
- Set img=new HashSet();
- img.add("aaa");
- img.add("bbb");
- img.add("aaa");
- c.setImg(img);
- m.addCustomer(c);
- }
- public void testDelCustomer() {
- m.delCustomer(2);
- }
- }
public class CustomerManagerImplTest extends TestCase {
CustomerManagerImpl m=new CustomerManagerImpl();
public void testAddCustomer() {
Customer c=new Customer();
c.setName("死亡骑士");
c.setAddress("五一九路");
c.setData(new Date());
Set img=new HashSet();
img.add("aaa");
img.add("bbb");
img.add("aaa");
c.setImg(img);
m.addCustomer(c);
}
public void testDelCustomer() {
m.delCustomer(2);
}
}
数据库中添加aaa、bbb字段,把重复的项去了。
List映射
将Customer.java中img注释改成如下
- /**
- * @hibernate.list
- * table="T_Img"
- * @hibernate.key
- * column="cid"
- * @hibernate.list-index
- * column="ind"
- * @hibernate.element
- * type="string"
- * column="name"
- */
- private List img;
/**
* @hibernate.list
* table="T_Img"
* @hibernate.key
* column="cid"
* @hibernate.list-index
* column="ind"
* @hibernate.element
* type="string"
* column="name"
*/
private List img;
在Img.java中添加一个索引字段ind
/**
* @hibernate.property
* column="ind"
*/
private int ind;
OK其它都和Set一样
数据库中添加aaa、bbb、aaa字段。充许添加重复项。
Map映射
和Set差不多,只是加了一个index项作为map的key
Customer.java改动
- /**
- * @hibernate.map
- * table="T_Img"
- * @hibernate.key
- * column="cid"
- * @hibernate.index
- * column="imgname"
- * type="string"
- * @hibernate.element
- * type="int"
- * column="size"
- */
- private Map img;
/**
* @hibernate.map
* table="T_Img"
* @hibernate.key
* column="cid"
* @hibernate.index
* column="imgname"
* type="string"
* @hibernate.element
* type="int"
* column="size"
*/
private Map img;
Img.java
- /**
- * @hibernate.property
- * column="imgname"
- */
- //键
- private String imgname;
- /**
- * @hibernate.property
- * column="size"
- */
- //值
- private int size;
/**
* @hibernate.property
* column="imgname"
*/
//键
private String imgname;
/**
* @hibernate.property
* column="size"
*/
//值
private int size;
测试:
- public void testAddCustomer() {
- Customer c=new Customer();
- c.setName("李白");
- c.setAddress("五一九路");
- c.setData(new Date());
- Map img=new HashMap();
- img.put("img4",32);
- img.put("img5",123);
- img.put("img4",97);
- c.setImg(img);
- m.addCustomer(c);
- }
public void testAddCustomer() {
Customer c=new Customer();
c.setName("李白");
c.setAddress("五一九路");
c.setData(new Date());
Map img=new HashMap();
img.put("img4",32);
img.put("img5",123);
img.put("img4",97);
c.setImg(img);
m.addCustomer(c);
}
数据库同样只添加了img4、img5,去除了重复项。
发表评论
-
hibernate n+1问题
2010-10-21 11:05 931Hibernate中常会用到set,bag等集合表示1对多的关 ... -
Hibernate 关联关系 总结
2010-09-09 15:27 9581.一对多的单向关联关系 配置单向的一对多关系是 ... -
Hibernate 关联
2010-09-09 15:24 10011、hibernate多对一关联映 ... -
Hibernate一对多(单向)
2010-09-09 14:31 594[正文]: Hibernate一对多关联,例如一个用户有 ... -
Hibernate中No row with the given identifier exists问题的原因及解决
2010-06-23 09:54 936产生此问题的原因: ... -
Hibernate使用count(*)取得表中记录总数(跨Hibernate3.x版本问题)
2010-06-22 17:13 1530Java代码 /** * @T ... -
hibernate继承关系映射
2010-06-13 16:58 919hbn 的继承映射关系有这 ... -
高并发网站的架构
2010-05-07 11:07 715我在CERNET做过拨号接入平台的搭建,而后在Yaho ... -
Hibernate事务和并发控制
2010-05-07 10:21 9141. 事务介绍:1.1. 事务的定义:事务就 ... -
hibernate中lazy的使用
2009-12-18 22:00 779lazy,延迟加载 Lazy的 ... -
Hibernate中代码自动生成功能小结
2009-12-06 15:10 1035Hibernate中需要class和mapping file, ... -
hibernate工具箱—根据映射文件自动建表
2009-12-04 12:08 977public class ExportDB { ... -
关联加载对象时的报错-----a different object with the same identifier value
2009-11-18 16:13 884因为在hibernate中同一个session里面有了两个相同 ... -
update/saveOrUpdate/merge
2009-11-18 15:28 1140通常下面的场景会使用update()或saveOrUpdate ... -
写得很不错的-Hibernate中的实体状态(二)
2009-11-18 15:08 949(2)session.merge ()方法 ... -
写得很不错的-Hibernate中的实体状态(一)
2009-11-18 15:04 1137持久层的解决方案有许 ... -
Hibernate3.x总结
2009-11-18 14:29 751Hibernate不是盏省油的灯 ... -
Hibernate Annotation几种关联映射
2009-11-02 17:01 1076Hibernate Annotation几种关联映射 一对一 ... -
hibernate3的注解映射学习
2009-11-02 16:41 1345注解映射必须满足两大条件:Hibernate3.2以上版本和J ... -
Hibernate 中级联操作 cascade 选项
2009-11-02 16:35 927none :在保存、更新或删除对象时,忽略其他关联的对象。他是 ...
相关推荐
本主题将深入探讨Hibernate集合映射与关联关系,包括"student与Score的Map集合关系"、"student与class的多对一"以及"一对多映射"的概念。 首先,让我们理解一下Hibernate中的集合映射。在关系型数据库中,一个实体...
《Hibernate集合映射详解》 Hibernate作为Java领域中的一款强大持久化框架,其核心功能之一就是对象关系映射(ORM),使得开发者可以方便地在Java对象与数据库表之间进行交互。其中,集合映射是Hibernate中非常关键...
在深入探讨Hibernate集合映射中的`inverse`与`cascade`属性之前,我们首先需要理解Hibernate框架的基本概念。Hibernate是一个开放源代码的对象关系映射(ORM)框架,它为Java应用程序提供了一种将对象模型与数据库...
Hibernate集合映射是ORM的重要组成部分,它使得Java对象和数据库表之间的关系更加直观和灵活。根据实际需求选择合适的集合类型,可以有效地处理复杂的数据关系。在实际应用中,应结合业务场景、数据特性以及性能需求...
Hibernate集合映射的基本概念 集合映射是Hibernate中一个核心的概念,它允许我们将数据库表中的多对一(OneToMany)、一对多(ManyToOne)、多对多(ManyToMany)等关系映射到Java对象的集合属性上。通过这种方式...
### Hibernate集合映射基础 1. **集合类型**:Hibernate支持多种集合类型映射,如Set、List、ArrayList、LinkedList、Map等。Set是最常见的集合映射类型,它不允许重复元素,与数据库中的唯一约束相对应。 2. **...
Hibernate 集合映射详解 Hibernate 是一个流行的Java持久化框架,它提供了多种集合映射类型,以满足不同的业务需求。在 Hibernate 中,集合映射是指将 Java 集合类型与数据库表之间的映射关系。常见的集合映射类型...
本文将深入讲解Hibernate中的集合映射,包括set、list、map和bag的配置与使用。 1. **Set集合映射** Set集合不允许有重复元素,因此在Hibernate中,set映射通常用于表示唯一性关系,如一对多关系。在Hibernate映射...
### JAVA培训-HIBERNATE的集合映射 #### 概述 本文主要聚焦于Hibernate框架下的集合映射机制,特别是针对`Set`、`List`、`Array`、`Map`、`Bag`五种集合...希望本文能帮助读者更好地理解和应用Hibernate集合映射技术。
标题中的“hibernate bag 集合映射”指的是Hibernate框架中的一种关系映射机制。Hibernate是一个流行的Java ORM(对象关系映射)框架,它允许开发者将数据库表与Java类进行映射,使得在处理数据库操作时可以使用面向...
**标题:“Hibernate List集合映射”** 在Java的持久化框架Hibernate中,集合映射是将数据库中的表与Java对象的集合属性关联的过程。List集合映射是其中常见的一种方式,它允许我们将数据库中的一组相关记录映射到...
这种映射可以通过集合类型如List、Set等来表示子项的集合。 2. **多对多关联映射**: 多对多关联是两个实体之间都可以有多个匹配项的情况,比如学生和课程的关系。在Hibernate中,我们可以使用`@ManyToMany`注解来...
在Java持久化框架Hibernate中,映射集合属性是常见的需求,特别是对于那些具有一对多、多对多关系的实体对象。这里的"List"是Java集合框架中的一个接口,用于存储一组有序的元素,而在Hibernate中,它常用来映射...
Hibernate,作为Java中广泛使用的对象关系映射(ORM)框架,提供了一种优雅的方式来映射枚举类型到数据库。本文将深入探讨Hibernate如何映射枚举类型,并给出实际应用示例。 ### Hibernate枚举映射方式 #### 1. `@...
在Java的持久化框架Hibernate中,集合映射是至关重要的一个概念,它允许我们将数据库中的表与Java对象的集合属性进行关联。本教程主要讲解了如何在Hibernate中配置和使用集合映射,以便更好地理解和应用这个强大的...
这里定义了一个名为`addresses`的集合,它映射到`person_address`表,并通过`person_id`列与`Address`类建立了一对多的关系。 此外,如果需要实现双向的一对多关系,还需要在`Address`类中添加对`Person`的引用: ...
在Java的持久化框架Hibernate中,数组映射是一种常见的数据模型转换方式,它允许我们将数据库中的数据以数组的形式存储在Java对象中。本篇将详细探讨`hibernate array 数组映射`的相关知识点,包括其原理、配置、...