@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);

参考技术A 是外键的名称 参考技术B 对应的是你数据库中定义的关联外键的字段 参考技术C 不懂本回答被提问者采纳

@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的主要内容,如果未能解决你的问题,请参考以下文章

@joincolumn 的休眠默认值

JoinColumn vs mappedBy

我可以在@OneToMany 上使用@JoinColumn 吗?

Hibernate @ManyToOne @JoinColumn 始终为空

JPA @JoinColumn 自定义对象类型

Hibernate不能使用@Table和@JoinColumn的问题