数据库有数据,但hibernate返回null

这两天发现一个奇怪的问题,我打开了hibernate显示sql的功能,用这个sql去数据库能查到数据,但是hibernate却一直返回null对象,不管是用Criteria去查,还是直接用hql查。

最后发现原因是之前的数据库表所有字段都不能为null,后面增加了一个字段,导致之前有一个字段可以为null了,而实体类的hibernate映射配置没有改,还是不允许为null,导致hibernate一直查不到数据,但是又不报错。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在SpringBoot,可以使用Hibernate Validator来进行数据校验。如果需要对数据库表新增、修改时的通用字段进行重复性校验,可以使用自定义注解和校验器来实现。 1. 自定义注解 首先,我们需要自定义一个注解,用来标记需要进行重复性校验的字段。比如,我们可以创建一个名为@Unique的注解,用来标记唯一性字段。 ``` @Target({ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) @Constraint(validatedBy = UniqueValidator.class) public @interface Unique { String message() default "该字段已存在"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; String value() default ""; } ``` 其,@Target注解用来指定注解的使用范围,这里我们指定为字段;@Retention注解用来指定注解的保留策略,这里我们指定为运行时保留;@Constraint注解用来指定注解的校验器,这里我们指定为UniqueValidator。 2. 自定义校验器 接下来,我们需要自定义一个校验器,用来对标记了@Unique注解的字段进行重复性校验。比如,我们可以创建一个名为UniqueValidator的校验器。 ``` public class UniqueValidator implements ConstraintValidator<Unique, Object> { @Autowired private JdbcTemplate jdbcTemplate; private String fieldName; @Override public void initialize(Unique constraintAnnotation) { fieldName = constraintAnnotation.value(); } @Override public boolean isValid(Object value, ConstraintValidatorContext context) { if (value == null) { return true; } String sql = "SELECT COUNT(*) FROM table_name WHERE " + fieldName + " = ?"; int count = jdbcTemplate.queryForObject(sql, Integer.class, value); return count == 0; } } ``` 其,@Autowired注解用来注入JdbcTemplate实例,以便进行数据库操作;initialize方法用来初始化校验器,这里我们获取@Unique注解指定的字段名;isValid方法用来实现具体的校验逻辑,这里我们使用JdbcTemplate查询数据库,判断指定字段的是否已存在。 3. 使用示例 最后,我们可以在实体类使用@Unique注解,对需要进行重复性校验的字段进行标记。 ``` public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Unique(value = "username") private String username; private String password; // ... } ``` 这样,在进行新增或修改操作时,就自动对标记了@Unique注解的字段进行重复性校验,如果发现重复,则抛出ConstraintViolationException异常。我们可以在Controller层进行异常处理,返回给前端友好的提示信息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值