- 浏览: 403074 次
- 性别:
- 来自: 珠海
文章分类
最新评论
-
一笑_奈何:
什么呀,写的不清不楚的。你是采用的什么监听事件呀
JQuery Mobile列表内容分版面异步加载(一) -
sf2gis:
谢谢,解决了。
搭建struts2,解决Tomcat启动时的错误:严重: Error filterStart -
effort0829:
其实解决办法很简单的,只要架上对应的jar包就可以了。
解决SSH的问题:NoClassDefFoundError: org/aopalliance/aop/Advice -
jianlangood:
受教了,感谢!
解决SSH的问题:NoClassDefFoundError: org/aopalliance/aop/Advice -
jsdsh:
好,太好了.谢谢
Open Chart Flash [ofc]图表示例一 (附图)
使用场合:
table1中主键id被table2作为外键引用,一条table1的记录可能有多条table2记录对应。
在页面上执行删除一条table1的操作, table1的id值传到java程序,删除table1的id=${id}之前必须删除table2关联的记录,因为有外键约束关系,所以必须先删除table2的相关记录,否则报错;而删除table2的记录不需要自己写代码删除, 因为有声明了hibernate one-to-many映射,直接删除table1的记录就行了。
不过要注意的是, 删除table1的记录前, 要先通过id获取table1的记录对象,否则无法删除成功。
举例==>
逻辑: 一个邮件接收用户可以关联多个产品, 如果删除了邮件接收用户, 那么产品关联邮件接收用户表的记录也要删除。
1) 数据库表:
2) Java代码:
/** TypeRelaUser.java */
/** TypeRelaUser.hbm.xml */
/** EmailUser.java */
/** EmailUser.hbm.xml */
/** EmailUserService.java */
/** EmailUserDAO.java */
table1中主键id被table2作为外键引用,一条table1的记录可能有多条table2记录对应。
在页面上执行删除一条table1的操作, table1的id值传到java程序,删除table1的id=${id}之前必须删除table2关联的记录,因为有外键约束关系,所以必须先删除table2的相关记录,否则报错;而删除table2的记录不需要自己写代码删除, 因为有声明了hibernate one-to-many映射,直接删除table1的记录就行了。
不过要注意的是, 删除table1的记录前, 要先通过id获取table1的记录对象,否则无法删除成功。
举例==>
逻辑: 一个邮件接收用户可以关联多个产品, 如果删除了邮件接收用户, 那么产品关联邮件接收用户表的记录也要删除。
1) 数据库表:
/*==============================================================*/ /* Table: 产品关联邮件接受用户表 */ /*==============================================================*/ CREATE TABLE IPMS_TYPE_RELA_USER ( ID varchar(64) not null, PROJTYPEID varchar(64) null, USERID varchar(64) null, constraint PK_IPMS_TYPE_RELA_USER primary key nonclustered (ID) ) go ALTER TABLE IPMS_TYPE_RELA_USER ADD CONSTRAINT FK_2 FOREIGN KEY (USERID) REFERENCES IPMS_EMAIL_USER (ID) go /*==============================================================*/ /* Table: 邮件接受用户表 */ /*==============================================================*/ CREATE TABLE IPMS_EMAIL_USER ( ID varchar(64) not null, NAME varchar(64) null, ACCOUNTS varchar(64) null, POSITION varchar(32) null, EMAIL varchar(100) null, constraint PK_IPMS_EMAIL_USER primary key nonclustered (ID) ) go
2) Java代码:
/** TypeRelaUser.java */
public class TypeRelaUser extends BaseData{ /** id */ private String id; /** 产品对象 */ private ProjectType projectType; /** 邮件接收用户对象 */ private EmailUser emailUser; public void setId(String id) { this.id = id; } public String getId() { return id; } public void setProjectType(ProjectType projectType) { this.projectType = projectType; } public ProjectType getProjectType() { return projectType; } public void setEmailUser(EmailUser emailUser) { this.emailUser = emailUser; } public EmailUser getEmailUser() { return emailUser; } }
/** TypeRelaUser.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> <class name="com.toone.ipms.projtype.rela.model.TypeRelaUser" table="IPMS_TYPE_RELA_USER"> <id name="id" type="java.lang.String" column="ID"> <generator class="uuid.hex" /> </id> <many-to-one name="projectType" column="PROJTYPEID" class="com.toone.ipms.projtype.type.model.ProjectType"> </many-to-one> <many-to-one name="emailUser" column="USERID" class="com.toone.ipms.emailuser.model.EmailUser"> </many-to-one> </class> <query name="getAllTypeRelaUsers"> from TypeRelaUser c order by c.id desc </query> <query name="deleteTypeRelaUsersByUserIds"> delete from TypeRelaUser c where c.emailUser.id in (:userIds) </query> </hibernate-mapping>
/** EmailUser.java */
public class EmailUser extends BaseData{ /** id */ private String id; /** 用户名 */ private String name; /** 账号 */ private String accounts; /** 职位 */ private String positionName; /** 邮件地址 */ private String email; /** 产品类型关联干系用户集合 */ private Set typeRelaUserSet = new HashSet(); /** 项目关联干系用户对象 */ private Set projRelaUserSet = new HashSet(); public void setTypeRelaUserSet(Set typeRelaUserSet){ this.typeRelaUserSet = typeRelaUserSet; } public Set getTypeRelaUserSet(){ return this.typeRelaUserSet; } public void setProjRelaUserSet(Set projRelaUserSet){ this.projRelaUserSet = projRelaUserSet; } public Set getProjRelaUserSet(){ return this.projRelaUserSet; } public void setId(String id) { this.id = id; } public String getId() { return id; } public void setName(String name) { this.name = name; } public String getName() { return name; } public void setAccounts(String accounts) { this.accounts = accounts; } public String getAccounts() { return accounts; } public void setPositionName(String positionName) { this.positionName = positionName; } public String getPositionName() { return positionName; } public void setEmail(String email) { this.email = email; } public String getEmail() { return email; } }
/** EmailUser.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> <class name="com.toone.ipms.emailuser.model.EmailUser" table="IPMS_EMAIL_USER"> <id name="id" type="java.lang.String" column="ID"> <generator class="uuid.hex" /> </id> <property name="name" type="java.lang.String" column="NAME" length="64" /> <property name="accounts" type="java.lang.String" column="ACCOUNTS" length="64" /> <property name="positionName" type="java.lang.String" column="POSITIONNAME" length="32" /> <property name="email" type="java.lang.String" column="EMAIL" length="100" /> <set name="typeRelaUserSet" lazy="false" inverse="true" cascade="delete"> <key column="USERID" /> <one-to-many class="com.toone.ipms.projtype.rela.model.TypeRelaUser" /> </set> <set name="projRelaUserSet" lazy="false" inverse="true" cascade="delete"> <key column="USERID" /> <one-to-many class="com.toone.ipms.proj.rela.model.ProjectRelaUser" /> </set> </class> <query name="getAllEmailUsers"> from EmailUser c order by c.name, c.accounts </query> <query name="checkExistEmailUser"> from EmailUser c where (c.id!=:id or :id is null) and (:name is null or c.name=:name) and (:accounts is null or c.accounts=:accounts) and (:email is null or c.email=:email) </query> </hibernate-mapping>
/** EmailUserService.java */
public class EmailUserService { protected EmailUserDAO emailUserDAO; public void setEmailUserDAO(EmailUserDAO emailUserDAO) { this.emailUserDAO = emailUserDAO; } /** * 删除一个邮件接收人信息对象 * @param emailUser EmailUser对象 */ public void deleteEmailUser(EmailUser emailUser) { emailUser = emailUserDAO.getEmailUserById(emailUser.getId()); //注意这里,先获取一个emailUser对象,这个对象可能包含会级联删除的产品关联用户表记录对象 //如果不先获取接收邮件用户对象,则删除会失败 emailUserDAO.deleteEmailUser(emailUser); } }
/** EmailUserDAO.java */
public class EmailUserDAO extends BaseDAO { /** * 通过id获得邮件接收人信息对象 * @param id * @return */ public EmailUser getEmailUserById( String id) { return (EmailUser)this.load(EmailUser.class, id); } /** * 删除一个邮件接收人信息对象 * @param emailUser EmailUser对象 */ public void deleteEmailUser(EmailUser emailUser) { this.delete(emailUser); } }
发表评论
-
理解Struts2的Action中的setter方法是怎么工作的
2012-05-01 22:11 6547接触过webwork和Struts2的同行都应该知道, ... -
解决SSH的问题:NoClassDefFoundError: org/aopalliance/aop/Advice
2012-04-30 13:54 27583在集成Struts2+Spring3+Hibern ... -
搭建struts2,解决Tomcat启动时的错误:严重: Error filterStart
2012-04-28 15:11 69041. 环境: JDK: jd ... -
Hibernate主键ID自动生成两种方法示例
2012-03-03 16:13 2877版本:hibernate-3.2.7 方法之一: 用uuid生 ... -
一个由hbm.xml文件格式不正确引发的悲催
2012-02-02 10:07 6136项目中运用了Hibernate3,报错如下: INFO ... -
Hibernate(HQL) 怪异的count()函数
2012-01-06 11:31 3764近日发现HQL中, count()函数要求还比较严格,举例说: ... -
基于SSH框架开发的JSP页面优化总结
2011-12-23 09:32 2185webwork2是struts2的前生,虽然struts ... -
webwork2使用细节
2011-11-15 10:49 1195记录一下webwork2使用细节,这些细节虽是小问题,可是不注 ... -
Hibernate(HQL) 子查询 formula公式运用
2011-11-02 17:07 2253写HQL时,除了where条件里可以用子查询,其它地方,如se ... -
Hql技巧积累之二:hbm.xml文件中经常犯的错
2011-05-15 15:16 2568Hibernate使用了*.hbm.xml来进行数据库表与ja ... -
Hql技巧积累之一:同时使用distinct和order by的问题
2010-12-20 11:22 5497所用数据库:ms server2000 所用hibernate ... -
Tomcat Server启动时报错: 请使用支持 JDBC 4.0 的 sqljdbc4.jar 类库
2010-11-19 00:11 5081以前一直做连接Oracle数据库的web项目, 今晚尝试搭建连 ... -
解决Failed to load class "org.slf4j.impl.StaticLoggerBinder"
2010-11-18 19:21 181147下载了hibernate-distribution-3.3.1 ... -
SQL 删除操作的语法在Hql中报错
2010-11-17 11:51 1549Hql中不能使用下面的删除语法, 但对应sql的语法是正确的。 ... -
SSH jar包冲突解决方法 - (struts2 spring2 hibernate3)
2010-08-29 11:20 4112SSH jar包冲突解决方法 - (struts2 sprin ...
相关推荐
"Hibernate one-to-many / many-to-one关系映射"是两个基本的关系类型,用于表示实体间的关联。在这个主题中,我们将深入探讨这两种关系映射的原理、配置和实际应用。 一、一对一(one-to-one)与一对多(one-to-...
以下是一个简单的例子,展示了一个班级(Class)与学生(Student)的one-to-many关系,以及学生对班级的many-to-one关系: ```java @Entity public class Class { @Id private Long id; @OneToMany(mappedBy =...
在Hibernate中,`one-to-many`关系是常见的实体间关系之一,表示一个实体可以与多个其他实体相关联。本文将深入探讨`Hibernate one-to-many`注解的使用和实现细节。 ### 一、`@OneToMany`注解概述 `@OneToMany`...
### Hibernate Many-to-One (多对一) 及 Cascade (级联) #### 一、Many-to-One(多对一) 在数据库设计中,实体之间的关系主要包括一对一、一对多、多对多等几种类型。而在ORM(对象关系映射)框架Hibernate中,...
本文将深入探讨Hibernate中一对多(One-to-Many)关系的处理方式,特别是通过外键映射和inverse属性的应用场景。 #### 一对多关系概念 一对多关系在数据库设计中非常常见,它指的是一个实体可以与多个其他实体关联...
本示例将详细讲解如何在Hibernate中实现多对多(many-to-many)的关系映射。 在数据库设计中,多对多关系是指两个实体之间存在多个关联,比如学生和课程的关系,一个学生可以选修多门课程,一门课程也可以被多个...
在本文中,我们将深入探讨如何使用Hibernate来实现多对多(many-to-many)的映射关系。 首先,多对多映射关系通常涉及到两个实体类之间的关联,例如在学生选课的例子中,学生(Student)和课程(Course)之间存在多...
本实例将详细讲解如何在Hibernate中实现Many-to-One关系映射,这是一种常见的数据库关联,表示一个实体可以与多个其他实体相关联。 在Many-to-One关系中,通常一个实体(如部门)可以有多个相关实体(如员工),而...
标题"Hibernate one to many(many to one) 配置"涉及到的是关系型数据库在Java中的持久化框架Hibernate中的两种关联映射关系:一对一(One-to-One)和多对一(Many-to-One)。在数据库设计中,这种关系很常见,例如...
本篇文章将深入探讨Hibernate中的关联映射,特别是"Many to One"关系的映射。在数据库设计中,Many to One是一种常见的关系,即一个实体(表)可以与多个其他实体相关联,而另一个实体则只与一个实体相关联。 首先...
本篇将详细阐述Hibernate中的对象三状态、一对一(OneToOne)、一对多(OneToMany)以及多对多(ManyToMany)关系映射。 一、Hibernate对象三状态 1. 游离态(Detached):对象在应用程序中创建,但尚未与Session...
在Java的持久化框架Hibernate中,集合映射是将数据库中的表关系映射到对象的集合属性上,以便更好地管理和操作数据。这篇文章将深入探讨Hibernate中的集合映射机制,包括其基本概念、类型以及如何在实际开发中进行...
《hibernate数据库映射例子.zip》这个压缩包包含了几个基于Hibernate框架的数据库映射示例,旨在帮助初学者理解并掌握如何在实际项目中应用Hibernate进行数据持久化操作。Hibernate是一个强大的Java对象关系映射...
-- 用来映射关联PO,必须为one-to-one元素增加constrained="true"属性 --> <one-to-one name="address" constrained="true"/> </hibernate-mapping> ``` --- ##### 3. 一对一连接表单向关联 在一对一连接表单...
3. **多对一(Many-to-One)关联**:与一对一关联相反,多个实体实例对应一个其他实体的实例。例如,多个订单(Order)可以关联到同一个客户(Customer)。 4. **多对多(Many-to-Many)关联**:一个实体可以关联多...
这种关系在Hibernate中使用`<one-to-many>`和`<set>`标签来表示: ```xml <!-- 其他属性省略 --> <set name="employees" table="EMP" cascade="save-update"> <key column="DEPTNO"></key> <one-to-many class...
【Hibernate映射例子详解】 Hibernate 是一款流行的 Java 开发中的对象关系映射(ORM)框架,它使得开发者可以通过 Java 对象来操作数据库,而无需直接编写 SQL 语句。映射是 Hibernate 中的核心概念,它定义了 ...