关于Hibernate使用组合主键时,组合主键中有些字段为null时的解决方法

当使用视图进行查询的时候,经常会使用组合主键的方式。

在hibernate中,配置在组合主键中的字段,若只要有一个的值为null那么,hibernate会将整行对应的实体置为null。

有时候,这并不是我们想要的。

网上比较多的解决方法就是:把可能为null的字段放到组合主键以外。

但是这样的话,组合主键里的字段就有可能不能唯一地标记一条记录,这样查询出来的结果往往也不是我们想要。


例如:原本有下面一个视图

年份院系姓名获奖数量
2010计算机学院张三26
2010计算机学院null27

我想查询某年某学院某位老师的获奖数量,这时候使用联合主键,包含年份,院系,姓名三个字段。

如果不采取任何手段,那么使用hibernate返回的结果列表第二条记录对应的实体为null,但是如果只使用年份跟院系作为联合主键,那么就不能区分这两条记录了。

我们可以这样做:

在创建视图的时候设置一列为ID,让ID的值为组合主键中的值的连接。

create or replace view myview as
select v1.年份||v1.院系||v1.姓名 as id...................................

这样上面的视图就会变为

ID年份院系姓名获奖数量
2010计算机学院张三2010计算机学院张三26
2010计算机学院2010计算机学院null27

这样当在hibernate中映射的时候就可以只映射一个字段ID作为主键,主键的生成方式为assigned,这样避免使用组合主键了,从而就没有了组合主键所带来的问题。

当然这种方法需要保证这三个字段至少有一个不为null。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 关于您的问题,我可以给出回答。在使用 Hibernate ,当将字段设置为空字符串Hibernate 会将该字段插入数据库,但是该字段将变为 NULL。这是因为在数据库,空字符串和 NULL 是不同的概念,空字符串表示该字段但为空,而 NULL 表示该字段没有。如果您希望将空字符串保存到数据库而不是变为 NULL,可以使用 Hibernate 的 @Column 注解的 nullable 属性设置为 false,如下所示: @Column(nullable = false) private String yourFieldName; 这将强制 Hibernate 将空字符串插入到数据库。 ### 回答2: 在使用Hibernate进行数据插入,如果将字段设置为空字符串,并且这个字段在数据库的表结构不允许为空(即设置了NOT NULL约束),那么Hibernate会将该字段插入为NULL。 这是因为Hibernate遵循数据库的约束规则,在某些数据库,将空字符串插入到不允许为空的字段会导致异常。为了避免这种情况,Hibernate会自动将空字符串转换为NULL来符合数据库的约束规则。 如果开发者想要将空字符串插入到数据库的某个字段,可以考虑以下两种方法: 1. 更改数据库表结构:将对应字段的约束改为允许为空,这样就可以插入空字符串了。 2. 使用自定义的setter方法:在实体类添加一个setter方法,在方法判断,如果传入参数为null或空字符串,则将其设置为一个自定义的(例如"空"),这样就可以将空字符串插入到数据库了。 总之,使用Hibernate,当字段设置为空字符串,但数据库表结构不允许为空Hibernate会将其插入为NULL,为了避免这种情况,可以修改表结构或自定义setter方法进行处理。 ### 回答3: 在使用Hibernate,当将字段设置为空字符串并尝试插入数据库,该空字符串会被转换为NULL。 这是因为Hibernate通过空间极小的Sequence Generator来判断实体是否有自动生成的主键。当字段被设置为为空字符串Hibernate会将其内部的字符串数据处理为空,因此在插入数据库会将其转换为NULL。 为了避免将空字符串转换为NULL,我们可以通过在实体的属性上设置注解来解决此问题。我们可以使用@NotEmpty注解来确保字段不为空字符串,例如: ``` @Entity public class ExampleEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @NotEmpty private String field; // 省略 getter 和 setter 方法 } ``` 通过将@NotEmpty注解添加到字段上,Hibernate将不允许将该字段设置为空字符串,并在插入验证注解的条件,如果字段为空字符串,将抛出异常。 另外,可以考虑使用@NotBlank注解来确保字段既不为空字符串也不为空白字符串,并且还可以使用@Column(nullable = false)来在数据库层面上强制该字段不为空。 综上所述,使用Hibernate,当字段被设置为空字符串并插入数据库,会被转换为NULL。我们可以通过标记注解来限制字段不为空字符串,从而避免将其转换为NULL
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值