gpt4 book ai didi

java - 如何在 Play 框架中为 embeddedId 实现 find() 或 findById() 方法

转载 作者:行者123 更新时间:2023-11-29 09:19:07 25 4
gpt4 key购买 nike

最近在用play framework做项目,非常感谢论坛里的 friend 们的帮助。现在我在玩游戏时又遇到了问题。我有一些具有唯一 ID(不是增量/默认 ID)的模型类,因此我扩展了 GenericModel 而不是我的 Model 类中的 Model。我对如何对 EmbeddedId 字段使用 GenericMODel 的 find() 或 findById() 方法感到困惑。这是我的代码片段:

模型类 1:

@Entity
@Table(name="DATKAPJMLPST")
public class Datkapjmlpst extends GenericModel {
//private static final long serialVersionUID = 1L;

@EmbeddedId
public DatkapjmlpstPK id;

@Column(name="BIAYAKAP")
public BigDecimal biayakap;

@Column(name="BPJ")
public BigDecimal bpj;

@Temporal( TemporalType.DATE)
@Column(name="DtProses")
public Date dtProses;

public String flag;

@Column(name="JmlPstKom")
public BigDecimal jmlPstKom;

@Column(name="JmlPstSos")
public BigDecimal jmlPstSos;

@Column(name="JmlPstTotal")
public BigDecimal jmlPstTotal;

@Column(name="KdDati2")
public String kdDati2;

//@Column(name="KdKC")
@ManyToOne
@JoinColumn(name="KDKC")
public Refkc refKC;

@Column(name="NOREG")
public String noreg;

public Datkapjmlpst() {
}

模型类 2:

@Embeddable
public class DatkapjmlpstPK extends GenericModel {

//default serial version id, required for serializable classes.
//private static final long serialVersionUID = 1L;

@Temporal(TemporalType.DATE)
@Column(name="Bln")
public Date bln;

//@Column(name="KdPPK")
@ManyToOne
@JoinColumn(name="KdPPK")
public Refppk refPPK;

@Column(name="KdBU")
public String kdBU;

public DatkapjmlpstPK() {
}

Controller 的方法:

public static void show(Date bln, String kdppk, String kdbu) {
JPAQuery datkapjmlpst = Datkapjmlpst.find("SELECT d FROM Datkapjmlpst d " +
"WHERE d.id.bln=? AND d.id.refPPK.kdppk=? AND d.id.kdBU=?", bln, kdppk, kdbu);

render(datkapjmlpst, bln, kdppk, kdbu);
}

观点:

#{form @edit(datkapjmlpst.id.bln, datkapjmlpst.id.refPPK.kdppk, datkapjmlpst.id.kdBU)}
<p>
<strong>Tanggal:</strong> ${datkapjmlpst.bln?.format('dd-MM-yyyy')}
</p>
<p>
<strong>Kantor Cabang:</strong> ${datkapjmlpst.refKC.nmkc}
</p>
<p>
<strong>BPJ:</strong> ${datkapjmlpst.bpj}
</p>
<p>
<strong>Jml Peserta Sosial:</strong> ${datkapjmlpst.jmlPstSos}
</p>
<p>
<strong>Status:</strong> ${datkapjmlpst.flag}
</p>

<p class="buttons">
<input type="submit" value="Edit Kapitasi"> <a href="@{index()}">Back to search</a>
</p>
#{/form}

这些代码有这样的错误输出:

Internal Server Error (500) for request GET /kapitasi/show?     kdbu=00000000&kdppk=00080001&bln=2011-04-01

Template execution error (In /app/views/Kapitasi/show.html around line 5)

模板/app/views/Kapitasi/show.html 中出现执行错误。引发的异常是 MissingPropertyException:没有这样的属性:类的 id:play.db.jpa.GenericModel$JPAQuery。

play.exceptions.TemplateExecutionException: No such property: id for class: play.db.jpa.GenericModel$JPAQuery
at play.templates.BaseTemplate.throwException(BaseTemplate.java:84)
at play.templates.GroovyTemplate.internalRender(GroovyTemplate.java:252)
at play.templates.Template.render(Template.java:26)
at play.templates.GroovyTemplate.render(GroovyTemplate.java:184)
at play.mvc.results.RenderTemplate.<init>(RenderTemplate.java:24)
at play.mvc.Controller.renderTemplate(Controller.java:659)
at play.mvc.Controller.renderTemplate(Controller.java:639)
at play.mvc.Controller.render(Controller.java:694)
at controllers.Kapitasi.show(Kapitasi.java:62)
at play.mvc.ActionInvoker.invokeWithContinuation(ActionInvoker.java:543)
at play.mvc.ActionInvoker.invoke(ActionInvoker.java:499)
at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:475)
at play.mvc.ActionInvoker.invokeControllerMethod(ActionInvoker.java:470)
at play.mvc.ActionInvoker.invoke(ActionInvoker.java:158)
at Invocation.HTTP Request(Play!)
Caused by: groovy.lang.MissingPropertyException: No such property: id for class: play.db.jpa.GenericModel$JPAQuery
at /app/views/Kapitasi/show.html.(line:5)
at play.templates.GroovyTemplate.internalRender(GroovyTemplate.java:229)
... 13 more

最佳答案

异常是提示您的 DatkapjmlpstPK 类缺少 @Id。您的 DatkapjmlpstPK 类是一个 EmbeddedId 类,因此它不需要扩展 GenericModel

关于java - 如何在 Play 框架中为 embeddedId 实现 find() 或 findById() 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7525538/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com