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;
};