- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不认为我的情况不寻常,但也许我遗漏了什么。这是数据库设置:
Table: proposalitems
Columns:
PK_ProposalRevisionItemID int(10) UN AI PK
FK_ProposalID int(10) UN
FK_RevisionID varchar(2)
ItemID int(10) UN
ItemText text
Delivery varchar(9)
Qty smallint(5) UN
PriceEach decimal(10,2) UN
LikelihoodOfSale tinyint(3) UN
FK_MfgTimeID int(10) UN
CREATE TABLE `proposalitems` (
`PK_ProposalRevisionItemID` int(10) unsigned NOT NULL AUTO_INCREMENT,
`FK_ProposalID` int(10) unsigned NOT NULL,
`FK_RevisionID` varchar(2) NOT NULL,
`ItemID` int(10) unsigned NOT NULL,
`ItemText` text,
`Delivery` varchar(9) DEFAULT 'Standard',
`Qty` smallint(5) unsigned DEFAULT '1',
`PriceEach` decimal(10,2) unsigned DEFAULT '0.00',
`LikelihoodOfSale` tinyint(3) unsigned NOT NULL DEFAULT '0',
`FK_MfgTimeID` int(10) unsigned DEFAULT NULL,
PRIMARY KEY (`PK_ProposalRevisionItemID`),
KEY `FK_MfgTime_idx` (`FK_MfgTimeID`),
KEY `FK_ItemPropRevID_idx` (`FK_ProposalID`,`FK_RevisionID`),
CONSTRAINT `FK_ItemPropRevID` FOREIGN KEY (`FK_ProposalID`, `FK_RevisionID`) REFERENCES `proposalrevisions` (`FK_ProposalID`, `FK_RevisionID`) ON DELETE CASCADE ON UPDATE NO ACTION,
CONSTRAINT `FK_MfgTime` FOREIGN KEY (`FK_MfgTimeID`) REFERENCES `proposalitemmnfgtimes` (`PK_ItemMnfgTimeID`)
) ENGINE=InnoDB AUTO_INCREMENT=6161 DEFAULT CHARSET=utf8;
proposalitems 是父表。
Table: proposalexpdelivery
Columns:
FK_ProposalRevisionItemID int(10) UN PK
DeliveryTime tinyint(3) UN
FK_DelUnitID int(10) UN
FK_DeliveryClauseID int(10) UN
CREATE TABLE `proposalexpdelivery` (
`FK_ProposalRevisionItemID` int(10) unsigned NOT NULL,
`DeliveryTime` tinyint(3) unsigned NOT NULL DEFAULT '4',
`FK_DelUnitID` int(10) unsigned DEFAULT NULL,
`FK_DeliveryClauseID` int(10) unsigned DEFAULT NULL,
PRIMARY KEY (`FK_ProposalRevisionItemID`),
KEY `FK_ExpDelUnitID` (`FK_DelUnitID`),
KEY `FK_ExpDeliveryClauseID` (`FK_DeliveryClauseID`),
CONSTRAINT `FK_ExpDelUnitID` FOREIGN KEY (`FK_DelUnitID`) REFERENCES `units` (`PK_UnitID`),
CONSTRAINT `FK_ExpDeliveryClauseID` FOREIGN KEY (`FK_DeliveryClauseID`) REFERENCES `proposaldeliveryclause` (`PK_DeliveryClauseID`),
CONSTRAINT `FK_expPropRevItemID` FOREIGN KEY (`FK_ProposalRevisionItemID`) REFERENCES `proposalitems` (`PK_ProposalRevisionItemID`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
基本上我有一个提案项目表。每件商品可能有也可能没有加急交货。如果是,加急递送记录将保存在 proposalexpdelivery 表中,使用与 proposalitems 表中相同的 id。我看到的大多数例子都有一对一的关系,如果一个存在,另一个也必须存在。就我而言,不必为每件商品都提供加急配送记录。
我只关心从提案项目中访问加急交付数据。不需要访问加急交付记录并从中获取提案项目数据。
这是 ProposalItem 的类:
@Entity
@Table(name="sales.proposalitems", uniqueConstraints=@UniqueConstraint(columnNames={"fk_proposalid","fk_revisionid","itemid"}))
public class ProposalItem implements Serializable {
...
private int proposalRevisionItemID;
...
private ProposalExpeditedDelivery expeditedDelivery;
...
@Id
@Column(name="pk_proposalrevisionitemid")
@GeneratedValue(strategy = GenerationType.IDENTITY)
@JsonView(View.SimpleProposalView.class)
public int getProposalRevisionItemID() {
return proposalRevisionItemID;
}
public void setProposalRevisionItemID(int proposalRevisionItemID) {
this.proposalRevisionItemID = proposalRevisionItemID;
}
...
// @OneToOne(optional=true,cascade={CascadeType.PERSIST,CascadeType.REMOVE}, orphanRemoval=true, mappedBy="proposalItem", fetch=FetchType.LAZY)
// @JoinColumn(name="pk_proposalrevisionitemid", referencedColumnName="fk_proposalrevisionitemid")
// @OneToOne(cascade=CascadeType.ALL, mappedBy="proposalItem")
// @Transient
// @OneToOne(optional=true,cascade={CascadeType.ALL}, orphanRemoval=true, fetch=FetchType.LAZY)
// @JoinColumn(name="pk_proposalrevisionitemid", referencedColumnName="fk_proposalrevisionitemid")
public ProposalExpeditedDelivery getExpeditedDelivery() {
return this.expeditedDelivery;
}
public void setExpeditedDelivery(ProposalExpeditedDelivery expeditedDelivery) {
this.expeditedDelivery = expeditedDelivery;
}
...
}
对于加急交付类:
@Entity
@Table(name="sales.proposalexpdelivery")
public class ProposalExpeditedDelivery implements Serializable {
...
private int proposalRevisionItemID;
private ProposalItem proposalItem;
...
@Id
@JoinColumn(name="fk_proposalrevisionitemid")
public int getProposalRevisionItemID() {
return proposalRevisionItemID;
}
public void setProposalRevisionItemID(int proposalRevisionItemID) {
this.proposalRevisionItemID = proposalRevisionItemID;
}
@OneToOne(fetch=FetchType.LAZY)
@JoinColumn(name="fk_proposalrevisionitemid")
@MapsId
public ProposalItem getProposalItem() {
return proposalItem;
}
public void setProposalItem(ProposalItem proposalItem) {
this.proposalItem = proposalItem;
}
...
}
我尝试过各种不同的东西。我可以成功检索到加急送达数据,但我一想更新或添加,就不行了。根据我当时使用的注释,我会得到各种各样的错误。
我有一个用于提案项的存储库和服务层。我在想,如果级联正常工作,我不需要这些来加快交付,但也许我错了。
在我的测试中,我试图同时设置项目中的交付和交付中的项目,我尝试为交付创建一个存储库,然后在保存项目之前保存交付,但我没有已尝试有效。
我很想看到一个清楚的示例,说明要使用哪些注释,以及理想情况下如何设置测试以添加和编辑对项目的交付,但我对正确的注释感到满意。
我正在使用 Spring Boot,它使用的是 Hibernate 5.2.12。
此外,我相信我的数据库结构设置正确且高效(我使用的是 MySQL),但如果有更好的方法来实现我的需要,我可以在需要时重组数据库。
编辑:
我用来测试它的代码有一个现有的 ProposalItem 对象。然后我创建一个新的 ProposalExpeditedDelivery 对象并尝试保存 ProposalItem。
ProposalExpeditedDelivery ped = new ProposalExpeditedDelivery();
ped.setDeliveryTime(4);
ped.setDeliveryUnit(unit);
ped.setDeliveryClause(clause);
//ped.setProposalItem(proposalItem);
proposalItem.setExpeditedDelivery(ped);
//expeditedDeliveryRepository.save(ped);
proposalItemRepository.save(proposalItem);
像这样(并使用 egallardo 的回答)我得到了错误:
org.hibernate.TransientPropertyValueException: object references an unsaved transient instance - save the transient instance before flushing
如果我取消注释该行以便它首先尝试保存 ProposalExpeditedDelivery 对象,我会收到错误消息:
attempted to assign id from null one-to-one property
如果我取消注释上面的两行注释,我会得到错误:
detached entity passed to persist
最佳答案
删除额外的 JoinColumn,只考虑对象(而不是数据库键):
@Entity
@Table(name="sales.proposalexpdelivery")
public class ProposalExpeditedDelivery implements Serializable {
...
private ProposalItem proposalItem;
...
@Id
@GenericGenerator(name = "generator", strategy = "foreign", parameters = @Parameter(name = "property", value = "proposalItem"))
@GeneratedValue(generator = "generator")
@JoinColumn(name="fk_proposalrevisionitemid", unique=true, nullable=false)
public int getProposalRevisionItemID() {
return proposalRevisionItemID;
}
@OneToOne(fetch=FetchType.LAZY)
@PrimaryKeyJoinColumn
public ProposalItem getProposalItem() {
return proposalItem;
}
public void setProposalItem(ProposalItem proposalItem) {
this.proposalItem = proposalItem;
}
...
}
父实体应该是这样的:
@Entity
@Table(name="sales.proposalitems", uniqueConstraints=@UniqueConstraint(columnNames={"fk_proposalid","fk_revisionid","itemid"}))
public class ProposalItem implements Serializable {
...
private int proposalRevisionItemID;
...
private ProposalExpeditedDelivery expeditedDelivery;
...
@Id
@Column(name="pk_proposalrevisionitemid", unique = true, nullable = false)
@GeneratedValue(strategy = GenerationType.IDENTITY)
@JsonView(View.SimpleProposalView.class)
public int getProposalRevisionItemID() {
return proposalRevisionItemID;
}
public void setProposalRevisionItemID(int proposalRevisionItemID) {
this.proposalRevisionItemID = proposalRevisionItemID;
}
...
@OneToOne(fetch = FetchType.LAZY,cascade=CascadeType.ALL,mappedBy="proposalItem")
public ProposalExpeditedDelivery getExpeditedDelivery() {
return this.expeditedDelivery;
}
public void setExpeditedDelivery(ProposalExpeditedDelivery expeditedDelivery) {
this.expeditedDelivery = expeditedDelivery;
}
...
}
测试代码:
retrieve proposalItem;
ProposalExpeditedDelivery ped = proposalItem.getExpeditedItem();
if(ped == null){
ped = new ProposalExpeditedDelivery();
ped.setProposalItem(proposalItem);
proposalItem.setExpeditedItem(ped);
expeditedDeliveryRepository.save(ped);
}
ped.setDeliveryTime(4);
ped.setDeliveryUnit(unit);
ped.setDeliveryClause(clause);
proposalItemRepository.save(proposalItem);
在 Proposal Items 的服务层,这里是更新代码:
@Override
public ProposalItem update(ProposalItem entity) throws EntityNotFoundException {
ProposalItem ent = null;
try {
ent = repository.findById(entity.getProposalRevisionItemID()).get();
} catch (Exception ex) {
LOGGER.error(ex.getMessage());
throw new EntityNotFoundException();
}
if (ent == null) {
throw new EntityNotFoundException();
}
// get the expedited delivery object from the existing database entry
ProposalExpeditedDelivery ped = ent.getExpeditedDelivery();
// if the existing database entry is null but the update client object does contain a ProposalExpeditedDelivery object
if (ped==null && entity.getExpeditedDelivery()!=null) {
entity.getExpeditedDelivery().setProposalItem(ent);
ent.setExpeditedDelivery(entity.getExpeditedDelivery());
expeditedDeliveryRepository.save(ent.getExpeditedDelivery());
}
// if the existing database entry has an expedited delivery object, but the client object does not
else if (ped!=null && entity.getExpeditedDelivery()==null) {
expeditedDeliveryRepository.delete(ped);
}
// if both the existing database entry and the client entry have an expedited delivery object, but they are not equal
else if (ped!=null && !ent.getExpeditedDelivery().equals(entity.getExpeditedDelivery())) {
ped.setDeliveryTime(entity.getExpeditedDelivery().getDeliveryTime());
ped.setDeliveryUnit(entity.getExpeditedDelivery().getDeliveryUnit());
ped.setDeliveryClause(entity.getExpeditedDelivery().getDeliveryClause());
expeditedDeliveryRepository.save(ent.getExpeditedDelivery());
}
entity = setupForUpdate(entity);
if (entity.getExpeditedDelivery()!=null) {
entity.setExpeditedDelivery(ent.getExpeditedDelivery());
}
return repository.save(entity);
}
更新的逻辑基本上是:
关于hibernate - spring data jpa一对一可选共享主键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47818876/
什么是 hibernate 和n- hibernate ?我可以在 Visual Studio 2008 中使用它进行 C# Web 应用程序开发吗?请给我建议...我是 asp.net Web 应用
我有一个不系统地发生的异常(exception)。 我试图通过在每次迭代中刷新和清理 session 来解决此问题,但没有成功。 [quartzScheduler_Worker-7] ERROR jd
使用 Hibernate 在数据库中存储 IP 地址的最佳类型是什么? 我虽然是 Byte[] 或 String,但有没有更好的方法,或者你用什么? @Column(name = "range_fr
我正在尝试制定一个公式来选择用户个人资料的用户友好名称。它选择名字 + ' ' + 姓氏 如果其中至少有一个不为空且不为空(包含非空白字符),否则选择 短名称 (条件相同),最后,如果 短名称 为空或
在hibernate中,是否可以将鉴别器作为一个实体?例如,如果我将 Department 作为基类,将 AdminDepartment 和 ProcessingDepartment 作为子类。 De
我只想从表中获取一些列值。因此,我已经使用投影来实现这一目标。该代码有效,但我认为它无效。 我的问题是当我使用ProjectionsList并将标准条件列表设置为ArrayList时-Bulletin
你好: 我对 hibernate 缓存缓存的内容感到困惑。 从文档中,我知道 hibernate 中有缓存类型。 一级 :交易级别。 似乎要被 session 持久化的实体被缓存在这里。 二级缓存 :
我遇到了一个情况: save或update hibernate 的目标表中的某些数据 在目标表上有一个触发器,该触发器将在目标表的insert或update操作之前执行 由 hibernate 将此记
我有一个名为 Master_Info_tbl 的表。它是一个查询表: 这是该表的代码: @Entity @Table(name="MASTER_INFO_T") public class Code
我想知道如何在 Hibernate 查询语言中使用日期文字。我在我的 JPA 项目中做了如下操作(作为 Eclipselink 提供者)并且它工作正常。 SELECT m FROM Me m WHER
@Entity public class Troop { @OneToMany(mappedBy="troop") public Set getSoldiers() { ...
我正在尝试使用 hibernate 查询删除表 'user_role' 中的所有行。但每次我都会出错。有人可以帮我吗。 DaoImpl @Override public void deleteAll(
不是将数据库操作分散在四个 (osgi) 包中,而是在那里做略有不同的事情。我想创建一个负责所有持久性问题的(简单的)OSGi 包。我觉得这并不像听起来那么简单,因为“每个包都有独特的类加载器”。 因
这就是我使用生成器的方式: private Integer id; 我看到的行为是: 创建第一个对象 hibernate 分配 id = 1 删除该对象 关闭服务
对象级别的实体和值类型有什么区别。我知道实体将有一个 id 但值不会,但为什么我们需要不同的方法来映射实体与值类型? 这样做是为了让hibernate可以对值类型应用任何优化吗? 最佳答案 一个实体已
我正在使用 HibernateTemplate.findByCriteria 方法进行一些查询。现在我想在标准上创建一些 SQL 限制,比如 criteria.add(Restrictions.sql
所以我有以下代码: Query query = session.createQuery("from Weather"); List list = query.list();
如何使用Hibernate映射具有多个实体的 View ? 问候, 混沌 最佳答案 请参见Hibernate文档中第5.1.3节“类”,紧接在“Id”节之前: There is no differen
据我所知,Hibernate 有两种类型的实现 JPA的实现(2)(@Entity,@Table注解) 扩展到旧的(传统的) hibernate (没有 JPA),使用 HSQL 查询,没有注释 如果
我需要一个将条目存储为键值对的集合(因此我可以通过键查找值),但我需要一个允许多个值使用 hibernate 共享同一个键的集合 最佳答案 一个键具有多个值的映射称为多映射 - 在 Apache 公共
我是一名优秀的程序员,十分优秀!