Sob*_*nka 0 java database jpa ebean playframework-2.0
我在Play Framework 2.2.3中有以下文件
控制器:
public class Comment extends Controller
{
public Result create(UUID id)
{
models.blog.Blog blog = models.blog.Blog.finder.byId(id);
Result result;
if(blog == null)
{
result = notFound(main.render("404", error404.render()));
}
else
{
Form<models.blog.Comment> commentForm = Form.form(models.blog.Comment.class);
commentForm = commentForm.bindFromRequest();
if(commentForm.hasErrors())
{
result = badRequest(Json.toJson(commentForm));
}
else
{
models.blog.Comment comment = commentForm.get();
comment.setId(UUID.randomUUID());
comment.setTimeCreated(new Date());
comment.setBlogId(blog.getId());
comment.save();
result = ok(Json.toJson(comment));
}
}
return result;
}
}
Run Code Online (Sandbox Code Playgroud)
还有两个型号
@Entity
@Table(name="blog")
public class Blog extends Model
{
private static final SimpleDateFormat MONTH_LITERAL = new SimpleDateFormat("MMMMM"),
DAY_NUMBER = new SimpleDateFormat("d"),
YEAR_NUMBER = new SimpleDateFormat("yyyy");
public static Finder<UUID, Blog> finder = new Finder<UUID, Blog>(UUID.class, Blog.class);
@Id
@Column(name="id",length=36, nullable=false)
public UUID id;
@OneToOne
@JoinColumn(name="author_id")
public User author;
@Column(name="title",length=255)
public String title;
@Column(name="summary",length=255)
public String summary;
@Column(name="url",length=255)
public String url;
@Column(name="content")
public String content;
@Column(name="time_updated")
public Date time_created;
@Column(name="time_created", nullable=false)
public Date time_updated;
@OneToMany(cascade = CascadeType.ALL)
@JoinColumn(name="blog_id")
public List<Comment> comments;
@ManyToMany(cascade = CascadeType.ALL)
@JoinTable(
name="blog_tag_map",
joinColumns={ @JoinColumn(name="blog_id", referencedColumnName="id") },
inverseJoinColumns={ @JoinColumn(name="tag_id", referencedColumnName="id") }
)
public List<Tag> tags;
public List<Comment> getComments()
{
return this.comments;
}
}
@Entity
@Table(name="blog_comment")
public class Comment extends Model
{
private static final SimpleDateFormat MONTH_LITERAL = new SimpleDateFormat("MMMMM"),
DAY_NUMBER = new SimpleDateFormat("d"),
YEAR_NUMBER = new SimpleDateFormat("yyyy");
@Id
@Column(name="id",length=36, nullable=false)
public UUID id;
@Column(name="blog_id", length=36)
public UUID blog_id;
@ManyToOne
public Blog blog;
@Column(name="content", length=500)
public String content;
@Column(name="website", length=255)
public String website;
@Column(name="name", length=255)
public String name;
@Column(name="time_created", updatable=false)
public Date time_created;
}
Run Code Online (Sandbox Code Playgroud)
为简洁起见,我已从这些模型中排除了一些限制器和吸气剂,因此它不会堵塞这篇文章.
当我尝试向上述控制器发出POST请求时,一切正常,直到我到达控制器文件中的"comment.save()"语句,然后我收到以下错误.
我不确定为什么这个保存不会通过,以及为什么存在列冲突.非常感谢
问题在于您在Comment的实体中基本上为Blog定义了两个外键列:
@Column(name = "blog_id", length = 36)
public UUID blog_id;
@ManyToOne
public Blog blog;
Run Code Online (Sandbox Code Playgroud)
"博客"字段的默认列名是:blog_id但是,您已经将"blog_id"列命名为.有趣的是,创建此表时不会抛出任何错误/警告......
因此,当您调用comment.save()时,将生成以下insert语句:
insert into blog_comment (id, blog_id, content, website, name, time_created, blog_id) values (?,?,?,?,?,?,?)
Run Code Online (Sandbox Code Playgroud)
请注意两次"blog_id"列的引用,该列无效.这是因为上面的双重映射.
要修复,只需为"blog"属性指定一个用于外键列的其他名称:
@Column(name = "blog_id", length = 36)
public UUID blog_id;
@ManyToOne
@JoinColumn(name = "blogId")
public Blog blog;
Run Code Online (Sandbox Code Playgroud)
我不确定你为什么要像这样映射你的实体(也许是遗留模式?)但是'blog_id'字段似乎是多余的(并且令人困惑),因为你已经有了'blog'属性形式的实体映射.
归档时间: |
|
查看次数: |
3777 次 |
最近记录: |