- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
你能帮我解决一些问题吗?我有两个实体项目和页面通过“一对多”连接:
项目模型(也与用户模型相关)
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@JsonProperty
private Integer id;
@ManyToOne(optional = false, fetch = FetchType.EAGER)
@JoinColumn(name = "username", referencedColumnName = "username", foreignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT))
private User user;
@Column(name="projectName", unique = true, nullable = false)
@JsonProperty
private String projectName;
@Column(name="style")
@JsonProperty
private String style;
@Column(name="menu")
@JsonProperty
private String menu;
@JsonProperty
@Fetch(value = FetchMode.SELECT)
@OneToMany(orphanRemoval=true, mappedBy = "project", cascade = {CascadeType.ALL}, fetch = FetchType.EAGER)
private Set<Page> pages;
//getters and setters
页面模型:
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@JsonProperty
private Integer id;
@Column(name="content")
@JsonProperty
private String content;
@Column(name="pageName", nullable = false)
@JsonProperty
private String pageName;
@ManyToOne(optional = false)
@JoinColumn(name = "project", referencedColumnName = "projectName", foreignKey = @ForeignKey(ConstraintMode.NO_CONSTRAINT))
private Project project;
//getters and setters
现在我想做这样的事情:
@Override
public void updatePages(Set<Page> pages, Integer projectId) {
Project project = entityManager.find(Project.class, projectId);
project.setPages(pages);
}
但是 Hibernate 查询没有结果和错误。
Hibernate:
select
project0_.id as id1_1_0_,
project0_.menu as menu2_1_0_,
project0_.projectName as projectN3_1_0_,
project0_.style as style4_1_0_,
project0_.username as username5_1_0_,
user1_.id as id1_4_1_,
user1_.email as email2_4_1_,
user1_.enabled as enabled3_4_1_,
user1_.password as password4_4_1_,
user1_.username as username5_4_1_,
userroles2_.username as username3_4_2_,
userroles2_.id as id1_2_2_,
userroles2_.id as id1_2_3_,
userroles2_.role as role2_2_3_,
userroles2_.username as username3_2_3_
from
projects project0_
inner join
users user1_
on project0_.username=user1_.username
left outer join
roles userroles2_
on user1_.username=userroles2_.username
where
project0_.id=?
Hibernate:
/* load project.model.User */ select
user0_.id as id1_4_2_,
user0_.email as email2_4_2_,
user0_.enabled as enabled3_4_2_,
user0_.password as password4_4_2_,
user0_.username as username5_4_2_,
projects1_.username as username5_4_4_,
projects1_.id as id1_1_4_,
projects1_.id as id1_1_0_,
projects1_.menu as menu2_1_0_,
projects1_.projectName as projectN3_1_0_,
projects1_.style as style4_1_0_,
projects1_.username as username5_1_0_,
userroles2_.username as username3_4_5_,
userroles2_.id as id1_2_5_,
userroles2_.id as id1_2_1_,
userroles2_.role as role2_2_1_,
userroles2_.username as username3_2_1_
from
users user0_
left outer join
projects projects1_
on user0_.username=projects1_.username
left outer join
roles userroles2_
on user0_.username=userroles2_.username
where
user0_.username=?
Hibernate:
select
pages0_.project as project4_1_0_,
pages0_.id as id1_0_0_,
pages0_.id as id1_0_1_,
pages0_.content as content2_0_1_,
pages0_.pageName as pageName3_0_1_,
pages0_.project as project4_0_1_
from
pages pages0_
where
pages0_.project=?
我想更新项目中的页面。最好的方法是什么?
UPD
Project project = entityManager.find(Project.class, projectId);
entityManager.createQuery("DELETE FROM Page p WHERE p.project = :project")
.setParameter("project",project)
.executeUpdate();
最佳答案
关联 Project-Pages 的所有者端位于 Page
实体上,在 hibernate 状态下(因为它解析双向一对多的方式),这意味着您必须设置 Page.project
对于您想要与 Project
链接的每个 Page
。如果您只将页面添加到项目的页面集合中,它将不起作用。
这样做,
@Override
public void updatePages(Set<Page> pages, Integer projectId) {
Project project = entityManager.find(Project.class, projectId);
for (Page p: pages) {
p.setProject (project);
//the pages are new? then also do em.persist(p)
}
}
根据您的实体模型,您现在看到的 select 语句需要检索项目并在调用 entityManager.find
方法时生成。
关于java - Hibernate jpa oneToMany : how to add to "one" list of many children,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31773936/
I have a question about adding files in git. I have found multiple stackoverflow questions about
我是 visual studio 的新手,来自 Delphi。 我有一个充满 .cs 文件的目录树(根是\Common)。 我还有一个充满应用程序的目录树(根目录是\Applications) 最后,
这个问题在这里已经有了答案: Array's lookup time complexity vs. how it is stored (4 个答案) Time complexity for java
谁能告诉我这两者有什么区别: ALTER TABLE x1 ADD INDEX(a); ALTER TABLE x1 ADD INDEX(b); 和 ALTER TABLE x1 ADD INDEX(
为什么有时我们使用 getChildren() add() 而其他时候我们直接使用 add() es: https://docs.oracle.com/javafx/2/get_started/for
如何使用 bootstrap css 在输入下方添加跨度?我需要做这样的事情: 最佳答案 是这样的吗? http://jsfiddle.net/swm53ran/205/ 您可以使用纯 CSS 来实现
问题 np.add(X, 2*Y, out=X) 比 np.add(X, Y, out=X); np.add(X, Y, out=X).使用 np.add(X, Y, out=X); 是一种实际做法吗
当我跑 git add --intent-to-add .所有未跟踪的文件将其状态从“未跟踪的文件”( git status -s 显示 ?? )更改为“未暂存以进行提交的更改”( git statu
我不知道 .add 之间有什么区别和 .sink.add ? 例子: StreamController myStreamController = StreamController(); stream
getContentPane().add() 和 add() 的意思一样吗? public class TestFrame extends JFrame{ public TestFrame()
git add . 和 git add * 会完成完全相同的事情吗? 最佳答案 不,不会。 * 是一个 glob 模式,不会匹配以 开头的文件。 例如,假设这是当前目录,我有 2 个新文件要添加 fo
git的分支与合并的两种方法 git add -A和 git add . git add -u在功能上看似很相近,但还是存在一点差别 git add . :他会
git add [--all | -A] 之间有什么区别?和 git add . ? 最佳答案 此答案仅适用于 Git 版本 1.x。对于 Git 版本 2.x,请参阅其他答案。 总结: git ad
我刚刚安装了最新的 Wix v3.7。我创建了一个 VS 2010“Excel 2010 加载项”项目,并在同一个解决方案中创建了一个 Wix“安装项目”。 问题是,当我尝试从 Wix 项目中引用 A
YUI.add 和 YUI().add 有什么区别? 最佳答案 在第一种情况下,您要注册一个模块可以加载到 YUI 沙箱中,在第二种情况下,您要构建一个沙箱,然后进行注册(这是一种非常不典型的用法)。
测试代码时,任何输入到列表中的值在按下“enter”后都会消失。 我对编程和网络开发非常陌生。请具体一点,以便我理解。 function addItem(){ var item = documen
我正在浏览 python 的 dis 包。我尝试了代码以查看它是如何工作的 >>> def get(): ... x=4 ... y=x+3 ............ this lin
我已经对我的文件夹进行了版本控制 git init git add . git commit -m 'Initial commit' 我应该怎么做 git add 对于我在 .? 中创建的每个新文件
当我执行 $ git add * 时,有时我意识到 git 不会将已删除的文件添加到舞台上,如果删除或添加它,我需要手动指示,但我想不通找出 $ git add --all 有什么区别。因此,如果星号
这个问题在这里已经有了答案: Difference between "git add -A" and "git add ." (12 个答案) 关闭 6 年前。 目前,当我想提交并将内容推送到远程
我是一名优秀的程序员,十分优秀!