使用hibernate注解,如何标识一个属性为非数据库的字段

使用hibernate注解,如何标识一个属性非数据库的字段。
就是说一个实体类对应了一张表,但是这个实体类中有一个属性不对应表中的字段

@Transient
    可选
    @Transient表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性.
    如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则,ORM框架默认其注解为@Basic
    示例:
    //根据birth计算出age属性
    @Transient
    public int getAge() {
       return getYear(new Date()) - getYear(birth);
    }

如果是数据库映射的字段 普通字段需要添加注解

 @Column(name = "PARAMNM", length = 50)
 public String getParamNm()
 {
  return this.paramNm;
 }

表id的话需要添加

@Id
 @GeneratedValue
 @Column(name = "ID", unique = true, nullable = false, precision = 22, scale = 0)
 public Long getId()
 {
  return this.id;
 }

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值