@JoinColumn(name = "") 到底填啥?如果随便填Unknown column 'optionvalu0_.optionId' in 'fi
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了@JoinColumn(name = "") 到底填啥?如果随便填Unknown column 'optionvalu0_.optionId' in 'fi相关的知识,希望对你有一定的参考价值。
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;
@Column(name = "products_options_id")
private String poid;
@Column(name = "language_id")
private String lid;
@Column(name = "products_options_values_id")
private String povid;
@Column(name = "products_options_values_name")
private String povname;
@ManyToOne(cascade = CascadeType.REFRESH, optional = false)
@JoinColumn(name = "")
private Option option;
-------------------------------------------------------------------------------------------------------
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;
@Column(name = "products_options_id")
private String pid;
@Column(name = "language_id")
private String lid;
@Column(name = "products_options_name")
private String poname;
@OneToMany(mappedBy = "option", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
private Set<OptionValue> optionValues = new HashSet<OptionValue>();
public Set<OptionValue> getOptionValues()
return optionValues;
public void setOrderItems(Set<OptionValue> optionValues)
this.optionValues = optionValues;
public void addLogRecordValue(OptionValue optionValue)
if (!this.optionValues.contains(optionValue))
this.optionValues.add(optionValue);
optionValue.setOption(this);
public void removeOptionValue(OptionValue optionValue)
optionValue.setOption(null);
this.optionValues.remove(optionValue);
@joincolumn 的休眠默认值
【中文标题】@joincolumn 的休眠默认值【英文标题】:Hibernate default value for @joincolumn 【发布时间】:2017-02-13 07:59:57 【问题描述】:我正在使用 jpa/hibernate
Country.java
@Column(nullable = false, name = "REGION")
private String region;
@Id
@Column(nullable = false, name = "CODE")
private String Code;
用户.java
@Column(nullable = false, name = "NAME")
private String name;
@NaturalId
@ManyToOne
@JoinColumn(name = "COUNTRY")
private Country country;
有没有一种方法可以为休眠中的国家/地区列的 User.java 中的 @joinColumn 设置默认值?
【问题讨论】:
参考此链接***.com/questions/197045/… 这可能对您有所帮助。 【参考方案1】:有没有一种方法可以为休眠中的国家/地区列的 User.java 中的 @joinColumn 设置默认值?
您可以使用columnDefinition
field in @JoinColumn
,但这取决于数据库,这不是最佳的。
@PrePersist
方法可能是更好的解决方案:
public class User
...
@PrePersist
public void prePersist()
if (country == null)
country = new Country("US");
有关其他替代示例,请参阅此答案:Setting default values for columns in JPA
【讨论】:
如果 Country 是我的数据库中当前不存在的列。所以我不确定模式升级将如何发生,考虑到它需要是@naturalId 并且不可为空?我问这个问题是因为我需要将现有记录更新为国家列的默认值 您的User
表中有国家/地区ID 或其他内容,对@banes?还是在连接表中?无论如何,@PrePersist
应该可以工作。以上是关于@JoinColumn(name = "") 到底填啥?如果随便填Unknown column 'optionvalu0_.optionId' in 'fi的主要内容,如果未能解决你的问题,请参考以下文章
我可以在@OneToMany 上使用@JoinColumn 吗?