Hibernate 代码生成和@Cascade({CascadeType.ALL})
Hibernate Code Generation and @Cascade({CascadeType.ALL})
请考虑以下 mySQL 个表格:
CREATE TABLE storeman.user (
id INT NOT NULL AUTO_INCREMENT,
email VARCHAR(50) NOT NULL,
display_name VARCHAR(50),
password CHAR(32),
...
PRIMARY KEY (id),
UNIQUE INDEX (email)
);
CREATE TABLE storeman.user_preferences (
id INT NOT NULL AUTO_INCREMENT,
notify_login BOOLEAN NOT NULL DEFAULT FALSE,
PRIMARY KEY (id),
CONSTRAINT fk_user_preferences FOREIGN KEY (id) REFERENCES user (id) ON DELETE CASCADE
);
如您所见,这两个表之间存在一对一的关系。
运行使用 Hibernate 代码生成器时,我得到以下信息(仅相关部分)
@Entity
@Table(name = "user", catalog = "storeman", uniqueConstraints = @UniqueConstraint(columnNames = "email"))
public class User implements java.io.Serializable {
...
@OneToOne(fetch = FetchType.LAZY, mappedBy = "user")
public UserPreferences getUserPreferences(){
return this.userPreferences;
};
...
}
问题是当我保存用户实体时,链接的用户首选项不会自动保存。解决这个很容易:
@OneToOne(fetch = FetchType.LAZY, mappedBy = "user")
@Cascade({CascadeType.ALL})
public UserPreferences getUserPreferences(){
return this.userPreferences;
};
但是,如果出于任何原因我必须再次重新 运行 Hibernate 代码生成器,@Cascade({CascadeType.ALL})
将会消失,这很危险,因为我依赖于以下事实链接表自动保存在我的代码中。
所以问题是:有没有办法修改顶部的 mySQL 脚本,以便在 运行 宁休眠逆向工程代码生成时,自动添加 @Cascade 注释?
mySql physical table 除了外键外,没有说任何关于级联的事情。只有它可以添加 ON DELETE CASCADE ON DELETE UPDATE。
那么你运行 Hibernate 代码生成器、CascadeType 和@Cascade 定义没有被翻译成DDL
尽量使用jpa注解。
@OneToOne(fetch = FetchType.LAZY, mappedBy = "user",cascade= CascadeType.ALL)
public UserPreferences getUserPreferences(){
return this.userPreferences;
};
请考虑以下 mySQL 个表格:
CREATE TABLE storeman.user (
id INT NOT NULL AUTO_INCREMENT,
email VARCHAR(50) NOT NULL,
display_name VARCHAR(50),
password CHAR(32),
...
PRIMARY KEY (id),
UNIQUE INDEX (email)
);
CREATE TABLE storeman.user_preferences (
id INT NOT NULL AUTO_INCREMENT,
notify_login BOOLEAN NOT NULL DEFAULT FALSE,
PRIMARY KEY (id),
CONSTRAINT fk_user_preferences FOREIGN KEY (id) REFERENCES user (id) ON DELETE CASCADE
);
如您所见,这两个表之间存在一对一的关系。 运行使用 Hibernate 代码生成器时,我得到以下信息(仅相关部分)
@Entity
@Table(name = "user", catalog = "storeman", uniqueConstraints = @UniqueConstraint(columnNames = "email"))
public class User implements java.io.Serializable {
...
@OneToOne(fetch = FetchType.LAZY, mappedBy = "user")
public UserPreferences getUserPreferences(){
return this.userPreferences;
};
...
}
问题是当我保存用户实体时,链接的用户首选项不会自动保存。解决这个很容易:
@OneToOne(fetch = FetchType.LAZY, mappedBy = "user")
@Cascade({CascadeType.ALL})
public UserPreferences getUserPreferences(){
return this.userPreferences;
};
但是,如果出于任何原因我必须再次重新 运行 Hibernate 代码生成器,@Cascade({CascadeType.ALL})
将会消失,这很危险,因为我依赖于以下事实链接表自动保存在我的代码中。
所以问题是:有没有办法修改顶部的 mySQL 脚本,以便在 运行 宁休眠逆向工程代码生成时,自动添加 @Cascade 注释?
mySql physical table 除了外键外,没有说任何关于级联的事情。只有它可以添加 ON DELETE CASCADE ON DELETE UPDATE。
那么你运行 Hibernate 代码生成器、CascadeType 和@Cascade 定义没有被翻译成DDL
尽量使用jpa注解。
@OneToOne(fetch = FetchType.LAZY, mappedBy = "user",cascade= CascadeType.ALL)
public UserPreferences getUserPreferences(){
return this.userPreferences;
};