java - 在 crud Play 1.2.4 中使用复合键路由到默认编辑模板

标签 java web-applications playframework crud playframework-1.x

我的数据库中有一个用户 ID 和用户角色的组合键。

为了将数据库与模型进行映射,代码如下:

    @Id
@Column(name="ID")
public int userId;
@Id
    @Column(name="USER_ROLE")
public String userRole;
......
    ......
    @Override
public String toString() {      
    return userId;
}

目前我可以显示用户列表,也可以为我的应用程序添加新用户。但是,当我尝试通过单击用户 ID 路由到默认的“编辑”模板时,我收到一条错误消息:“无路由”。

另外,我可以看到在用户点击时,复合 ID 没有作为 URL 发送,实际上一些对象被附加到 url 的末尾(这可能是一个原因)。

请告诉我当我们在数据库中有复合键时如何显示默认编辑屏幕。很长一段时间以来,我一直在努力解决这个问题,但在文档中没有得到任何引用资料:(

最佳答案

Play CRUD Controller 不适用于复合键。以下是解决方法。

首先,确定复合键的字符串化格式 - 在下面的示例中,我刚刚采用了两个键(ssn、accountId)并将它们连接在一起,用“-”分隔。

在您的模型中,重写来自 GenericModel 和 JPABase 的 _keyfindById 方法,如下所示:

package models;

import play.db.jpa.GenericModel;

import javax.persistence.Entity;
import javax.persistence.Id;    

@Entity
public class Part extends GenericModel {
    @Id
    public int ssn;
    @Id
    public int accountId;
    public String name;

    /**
     * Find a part by its composite id ("ssn-accountId")
     */
    public static Part findById(String id) {
        // Split the composite id to extract ssn and accountId
        String[] elements = id.split("-");
        int ssn = Integer.valueOf(elements[0]);
        int accountId = Integer.valueOf(elements[1]);

        return Part.find("ssn=? AND accountId=?", ssn, accountId).first();
    }

    /**
     * Return a composite id ("ssn-accountId")
     */
    public String _key() {
        return ssn + "-" + accountId;
    }
}

接下来重写 Controller 中的 show 方法:

    package controllers;

    import models.Part;

    public class Parts extends CRUD {

    /**
     * CRUD show method doesn't know how to handle composite ids.
     *
     * @param id composite of ssn + "-" + accountId
     * @throws Exception
     */
    public static void show(String id) throws Exception {
        // Do not rename 'type' or 'object'
        ObjectType type = ObjectType.get(getControllerClass());
        notFoundIfNull(type);
        Part object = Part.findById(id);
        notFoundIfNull(object);
        render("CRUD/show.html", type, object);
    }
}

就是这样。

关于java - 在 crud Play 1.2.4 中使用复合键路由到默认编辑模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17058874/

相关文章:

html - 响应式设计单元

java - 我可以创建一个 Play!框架项目并使用现有的 Java 代码?

使用 flex-plugin 部署时的 Java 堆空间

java - Java Servlet 中的产品浏览

asp.net - 如何在 https ://localhost in a development environment? 上测试我的 ASP.NET 页面

html - 如何为不同的屏幕 ReactJS 设置不同的背景

json - JSON字符串中的org.codehaus.jackson.map.JsonMappingException : Can not instantiate value of type [simple type,类模型。

json - Scala 编译器 (2.11.7) 与 Play JSON 写入异常

java - 使用 JGit 从 Git 存储库中 check out 特定修订

java/Swing : drag and drop with a list of strings