- 浏览: 138868 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
cl1154781231:
谢谢,总算找到一个有用的!
plsql:导入excel数据(手动快速方式) -
RonQi:
很好很强大 今天MyEclipse6.5提示我还有一个月注册码 ...
MyEclipse 6.5 注册机源码 -
tanlingcau:
lixiansky 写道 你上面的写错啦!!!!从网上抄也得试 ...
tomcat在windows下开机自动运行 -
lixiansky:
你上面的写错啦!!!!从网上抄也得试试吧!!!!郁闷.... ...
tomcat在windows下开机自动运行 -
gadflyyy:
标题错了,是导入excel
plsql:导入excel数据(手动快速方式)
Hibernate 映射视图会生成联合主键.在查询时,如果联合主键里有一项值为null,则整个结果返回null.
原文件:由Hibernate生成:
V4cDiseasesprevention.java
V4cDiseasespreventionId.java
映射文件:V4cDiseasesprevention.hbm.xml
解决方案:把视图当作表处理
1.将将V4cDiseasesprevention.java的属性全部替换为V4cDiseasespreventionId.java的,以及它的get,set方法.
2.删除V4cDiseasespreventionId.java;
3.修改映射文件为:
原文件:由Hibernate生成:
V4cDiseasesprevention.java
package com.SAFAS.mobilecatch.server.hibernate.model; /** * V4cDiseasesprevention entity. * * @author MyEclipse Persistence Tools */ public class V4cDiseasesprevention implements java.io.Serializable { // Fields private V4cDiseasespreventionId id; // Constructors /** default constructor */ public V4cDiseasesprevention() { } /** full constructor */ public V4cDiseasesprevention(V4cDiseasespreventionId id) { this.id = id; } // Property accessors public V4cDiseasespreventionId getId() { return this.id; } public void setId(V4cDiseasespreventionId id) { this.id = id; } }
V4cDiseasespreventionId.java
package com.SAFAS.mobilecatch.server.hibernate.model; /** * V4cDiseasespreventionId entity. * * @author MyEclipse Persistence Tools */ public class V4cDiseasespreventionId implements java.io.Serializable { // Fields private Integer produceClassify4id; private String produceClassify4name; private Short qualityStandardId; private Short environmentStandardId; private Short producingRuleId; private Short produceSampleStandardId; private String producingRuleCode; private String producingRuleName; private String remark; private String pesticideName; private String preventionMethod; // Constructors /** default constructor */ public V4cDiseasespreventionId() { } /** minimal constructor */ public V4cDiseasespreventionId(Integer produceClassify4id) { this.produceClassify4id = produceClassify4id; } /** full constructor */ public V4cDiseasespreventionId(Integer produceClassify4id, String produceClassify4name, Short qualityStandardId, Short environmentStandardId, Short producingRuleId, Short produceSampleStandardId, String producingRuleCode, String producingRuleName, String remark, String pesticideName, String preventionMethod) { this.produceClassify4id = produceClassify4id; this.produceClassify4name = produceClassify4name; this.qualityStandardId = qualityStandardId; this.environmentStandardId = environmentStandardId; this.producingRuleId = producingRuleId; this.produceSampleStandardId = produceSampleStandardId; this.producingRuleCode = producingRuleCode; this.producingRuleName = producingRuleName; this.remark = remark; this.pesticideName = pesticideName; this.preventionMethod = preventionMethod; } // Property accessors public Integer getProduceClassify4id() { return this.produceClassify4id; } public void setProduceClassify4id(Integer produceClassify4id) { this.produceClassify4id = produceClassify4id; } public String getProduceClassify4name() { return this.produceClassify4name; } public void setProduceClassify4name(String produceClassify4name) { this.produceClassify4name = produceClassify4name; } public Short getQualityStandardId() { return this.qualityStandardId; } public void setQualityStandardId(Short qualityStandardId) { this.qualityStandardId = qualityStandardId; } public Short getEnvironmentStandardId() { return this.environmentStandardId; } public void setEnvironmentStandardId(Short environmentStandardId) { this.environmentStandardId = environmentStandardId; } public Short getProducingRuleId() { return this.producingRuleId; } public void setProducingRuleId(Short producingRuleId) { this.producingRuleId = producingRuleId; } public Short getProduceSampleStandardId() { return this.produceSampleStandardId; } public void setProduceSampleStandardId(Short produceSampleStandardId) { this.produceSampleStandardId = produceSampleStandardId; } public String getProducingRuleCode() { return this.producingRuleCode; } public void setProducingRuleCode(String producingRuleCode) { this.producingRuleCode = producingRuleCode; } public String getProducingRuleName() { return this.producingRuleName; } public void setProducingRuleName(String producingRuleName) { this.producingRuleName = producingRuleName; } public String getRemark() { return this.remark; } public void setRemark(String remark) { this.remark = remark; } public String getPesticideName() { return this.pesticideName; } public void setPesticideName(String pesticideName) { this.pesticideName = pesticideName; } public String getPreventionMethod() { return this.preventionMethod; } public void setPreventionMethod(String preventionMethod) { this.preventionMethod = preventionMethod; } public boolean equals(Object other) { if ((this == other)) return true; if ((other == null)) return false; if (!(other instanceof V4cDiseasespreventionId)) return false; V4cDiseasespreventionId castOther = (V4cDiseasespreventionId) other; return ((this.getProduceClassify4id() == castOther .getProduceClassify4id()) || (this.getProduceClassify4id() != null && castOther.getProduceClassify4id() != null && this .getProduceClassify4id().equals( castOther.getProduceClassify4id()))) && ((this.getProduceClassify4name() == castOther .getProduceClassify4name()) || (this .getProduceClassify4name() != null && castOther.getProduceClassify4name() != null && this .getProduceClassify4name().equals( castOther.getProduceClassify4name()))) && ((this.getQualityStandardId() == castOther .getQualityStandardId()) || (this .getQualityStandardId() != null && castOther.getQualityStandardId() != null && this .getQualityStandardId().equals( castOther.getQualityStandardId()))) && ((this.getEnvironmentStandardId() == castOther .getEnvironmentStandardId()) || (this .getEnvironmentStandardId() != null && castOther.getEnvironmentStandardId() != null && this .getEnvironmentStandardId().equals( castOther.getEnvironmentStandardId()))) && ((this.getProducingRuleId() == castOther .getProducingRuleId()) || (this.getProducingRuleId() != null && castOther.getProducingRuleId() != null && this .getProducingRuleId().equals( castOther.getProducingRuleId()))) && ((this.getProduceSampleStandardId() == castOther .getProduceSampleStandardId()) || (this .getProduceSampleStandardId() != null && castOther.getProduceSampleStandardId() != null && this .getProduceSampleStandardId().equals( castOther.getProduceSampleStandardId()))) && ((this.getProducingRuleCode() == castOther .getProducingRuleCode()) || (this .getProducingRuleCode() != null && castOther.getProducingRuleCode() != null && this .getProducingRuleCode().equals( castOther.getProducingRuleCode()))) && ((this.getProducingRuleName() == castOther .getProducingRuleName()) || (this .getProducingRuleName() != null && castOther.getProducingRuleName() != null && this .getProducingRuleName().equals( castOther.getProducingRuleName()))) && ((this.getRemark() == castOther.getRemark()) || (this .getRemark() != null && castOther.getRemark() != null && this.getRemark() .equals(castOther.getRemark()))) && ((this.getPesticideName() == castOther.getPesticideName()) || (this .getPesticideName() != null && castOther.getPesticideName() != null && this .getPesticideName() .equals(castOther.getPesticideName()))) && ((this.getPreventionMethod() == castOther .getPreventionMethod()) || (this.getPreventionMethod() != null && castOther.getPreventionMethod() != null && this .getPreventionMethod().equals( castOther.getPreventionMethod()))); } public int hashCode() { int result = 17; result = 37 * result + (getProduceClassify4id() == null ? 0 : this .getProduceClassify4id().hashCode()); result = 37 * result + (getProduceClassify4name() == null ? 0 : this .getProduceClassify4name().hashCode()); result = 37 * result + (getQualityStandardId() == null ? 0 : this .getQualityStandardId().hashCode()); result = 37 * result + (getEnvironmentStandardId() == null ? 0 : this .getEnvironmentStandardId().hashCode()); result = 37 * result + (getProducingRuleId() == null ? 0 : this.getProducingRuleId() .hashCode()); result = 37 * result + (getProduceSampleStandardId() == null ? 0 : this .getProduceSampleStandardId().hashCode()); result = 37 * result + (getProducingRuleCode() == null ? 0 : this .getProducingRuleCode().hashCode()); result = 37 * result + (getProducingRuleName() == null ? 0 : this .getProducingRuleName().hashCode()); result = 37 * result + (getRemark() == null ? 0 : this.getRemark().hashCode()); result = 37 * result + (getPesticideName() == null ? 0 : this.getPesticideName() .hashCode()); result = 37 * result + (getPreventionMethod() == null ? 0 : this .getPreventionMethod().hashCode()); return result; } }
映射文件:V4cDiseasesprevention.hbm.xml
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!-- Mapping file autogenerated by MyEclipse Persistence Tools --> <hibernate-mapping> <class name="com.SAFAS.mobilecatch.server.hibernate.model.V4cDiseasesprevention" table="v_4c_diseasesprevention" catalog="safas"> <composite-id name="id" class="com.SAFAS.mobilecatch.server.hibernate.model.V4cDiseasespreventionId"> <key-property name="produceClassify4id" type="java.lang.Integer"> <column name="produceClassify_4ID" /> </key-property> <key-property name="produceClassify4name" type="java.lang.String"> <column name="produceClassify_4Name" length="20" /> </key-property> <key-property name="qualityStandardId" type="java.lang.Short"> <column name="qualityStandardID" /> </key-property> <key-property name="environmentStandardId" type="java.lang.Short"> <column name="environmentStandardID" /> </key-property> <key-property name="producingRuleId" type="java.lang.Short"> <column name="producingRuleID" /> </key-property> <key-property name="produceSampleStandardId" type="java.lang.Short"> <column name="produceSampleStandardID" /> </key-property> <key-property name="producingRuleCode" type="java.lang.String"> <column name="producingRuleCode" /> </key-property> <key-property name="producingRuleName" type="java.lang.String"> <column name="producingRuleName" length="50" /> </key-property> <key-property name="remark" type="java.lang.String"> <column name="remark" /> </key-property> <key-property name="pesticideName" type="java.lang.String"> <column name="pesticideName" length="50" /> </key-property> <key-property name="preventionMethod" type="java.lang.String"> <column name="preventionMethod" /> </key-property> </composite-id> </class> </hibernate-mapping>
解决方案:把视图当作表处理
1.将将V4cDiseasesprevention.java的属性全部替换为V4cDiseasespreventionId.java的,以及它的get,set方法.
2.删除V4cDiseasespreventionId.java;
3.修改映射文件为:
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!-- Mapping file autogenerated by MyEclipse Persistence Tools --> <hibernate-mapping> <class name="com.SAFAS.mobilecatch.server.hibernate.model.V4cDiseasesprevention" table="v_4c_diseasesprevention" catalog="safas"> <id name="produceClassify4id" type="java.lang.Integer"> <column name="produceClassify_4ID" /> </id> <property name="produceClassify4name" type="java.lang.String"> <column name="produceClassify_4Name" length="20" /> </property> <property name="qualityStandardId" type="java.lang.Short"> <column name="qualityStandardID" /> </property> <property name="environmentStandardId" type="java.lang.Short"> <column name="environmentStandardID" /> </property> <property name="producingRuleId" type="java.lang.Short"> <column name="producingRuleID" /> </property> <property name="produceSampleStandardId" type="java.lang.Short"> <column name="produceSampleStandardID" /> </property> <property name="producingRuleCode" type="java.lang.String"> <column name="producingRuleCode" /> </property> <property name="producingRuleName" type="java.lang.String"> <column name="producingRuleName" length="50" /> </property> <property name="remark" type="java.lang.String"> <column name="remark" /> </property> <property name="pesticideName" type="java.lang.String"> <column name="pesticideName" length="50" /> </property> <property name="preventionMethod" type="java.lang.String"> <column name="preventionMethod" /> </property> </class> </hibernate-mapping>
评论
2 楼
tanlingcau
2010-10-19
这个我已经完全记不清楚了,而且项目也没有留档,不好意思。
1 楼
livexu
2010-10-19
<id name="produceClassify4id" type="java.lang.Integer">
<column name="produceClassify_4ID" />
</id>
是唯一的字段?
<column name="produceClassify_4ID" />
</id>
是唯一的字段?
发表评论
文章已被作者锁定,不允许评论。
-
Null value was assigned to a property of primitive type setter of
2009-10-11 19:58 4939Exception: org.hibernate.Proper ... -
Hibernate 查询视图
2008-09-26 11:37 2477V4cDiseasesprevention package ... -
Hibernate load()和get()的区别
2008-09-24 17:47 808Session的load()和get()方法所载入的对象必定是 ... -
Hibernate内置持久化标志符生成器的区别
2008-09-24 17:07 9561.increment(递增) 只有在没有其他进程往 ...
相关推荐
它支持实体类(Entity)、持久化字段(Field)、主键(Id)、一对多(OneToMany)、多对一(ManyToOne)、多对多(ManyToMany)等关系映射。 3. Spring:Spring框架是Java企业级应用的核心。它提供了一个容器...
- **一对一关系**:可以通过主键联合或者外键关联两种方式实现。 - **一对多关系**:通常是通过外键关联的方式实现,即在“多”的一方添加指向“一”的外键字段。 - **多对多关系**:通常需要一个中间表来关联...
多表操作则可能涵盖多对多关联,需要理解联合主键、中间表等概念。 在实际项目中,整合这些技术的关键在于配置和协调。例如,Struts 需要配置 Action 映射和结果页面,Hibernate 需要配置实体类和映射文件,而 ...
- **一对一关系:** 表示两个实体之间存在一对一的关联,通常通过主键外键的方式实现,也可以通过联合主键的方式表示。 - **一对多关系:** 一个实体对应多个实体的关系,可以通过外键表示。在 Hibernate 中,可以...
在IT行业中,构建高效、可维护的Web应用是至关重要的,SpringMVC、Hibernate和JPA作为Java领域中三大主流框架,常常被联合使用来实现这一目标。本篇将详细介绍如何利用Maven来搭建整合SpringMVC、Hibernate和JPA的...
例如,在示例代码中,通过`from tBookInfo book, BookSelection sel where book.id = sel.bookId`这样的HQL语句,实现了对“书籍”和“选择”两个表的联合查询,并根据主键与外键的关系进行了匹配。 #### 2. 构建...
- **联合主键**:在Hibernate中,可以通过创建一个类来表示联合主键,并实现Serializable接口,重写equals()和hashCode()方法。在配置文件中使用`<composite-id>`替代`<id>`标签,指定类路径。 - **load()与get()...
实体类需要包含双向@ManyToMany注解,而映射文件则需指定中间表的配置,包括联合主键等。 3. **JPA注解**:在Java中,使用Java Persistence API (JPA) 的@ManyToMany注解可以声明多对多关系。这个注解会在两个关联...
字段可能为`user_id`和`role_id`,两者作为联合主键。 6. **评论表**:如果系统支持用户评论,这个表将存储评论内容、评论者、被评论的新闻ID等。字段可能包括`comment_id`(主键)、`content`、`user_id`、`news_...
**Hibernate的联合主键:** - 通过定义复合主键来唯一标识一个实体对象。 - 可以是多个字段的组合。 **缓存框架:** - 如Ehcache、OSCache等,用于改善应用性能。 - 支持数据的高速读取和写入。 **iBATIS与...
4. **持久化上下文(Persistence Context)**: 存储了实体的内存视图,管理实体的状态和生命周期。在事务范围内,实体的修改会被自动同步到数据库。 ### JPA核心特性 1. **对象/关系映射(ORM)**: 使用注解或XML...
10.5 联合军种作战的混乱 10.5.1 Spring事务管理器的应对 10.5.2 Hibernate+Spring JDBC混合框架的事务管理 10.6 特殊方法成漏网之鱼 10.6.1 哪些方法不能实施Spring AOP事务 10.6.2 事务增强遗漏实例 10.7 数据连接...
10.5 联合军种作战的混乱 10.5.1 Spring事务管理器的应对 10.5.2 Hibernate+Spring JDBC混合框架的事务管理 10.6 特殊方法成漏网之鱼 10.6.1 哪些方法不能实施Spring AOP事务 10.6.2 事务增强遗漏实例 10.7 数据连接...
- **对象关系映射**:介绍对象与关系型数据库之间的映射关系。 - **对象关系数据库**:学习对象关系数据库的特性和优势。 - **ORM框架**:掌握Hibernate、JPA等ORM框架的应用。 #### 二十八、其他数据库 - **MySQL*...
MyBatis使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plan Old Java Objects,普通的Java对象)映射成数据库中的记录. orm工具的基本思想 无论是用过的hibernate,mybatis,你都可以法相他们有一个...