Hibernate.initialize(Obj)用法

  在使用hibernate进行持久化时,有时需要动态的改变对象的加载,比如在编辑页面里面lazy=true,而在浏览页面lazy=false,这样可以在需要lazy的地方才进行控制。而配置文件中Lazy属性是全局控制的,如何处理呢? 
  当元素或者元素的lazy属性为true时,load() or get() or find()加载这些对象时,Hibernate不会马上产生任何select语句,只是产生一个Obj代理类实例,只有在session没有关闭的情况下运行Obj.getXxx()时才会执行select语句从数据库加载对象,如果没有运行任何Obj.getXxx()方法,而session已经关闭,Obj已成游离状态,此时再运行Obj.getXxx()方法,Hibernate就会抛出"Could not initialize proxy - the owning Session was closeed"的异常,是说Obj代理类实例无法被初始化。然而想在Session关闭之前不调用Obj.getXxx()方法而关闭Session之后又要用,此时只要在Session关闭之前调用Hibernate.initialize(Obj)或者Hibernate.initialize(Obj.getXxx())即可,net.sf.hibernate.Hibernate类的initialize()静态方法用于在Session范围内显示初始化代理类实例。 

  在配置文件里面可以用lazy=true,在程序里面可以用强制加载的方法Hibernate.initialize(Object proxy) 方法强制加载这样就相当于动态改变为lazy=false。 


  但在使用时需要注意的一点是:

                其中的proxy是持久对象的关联对象属性,比如A实体,你要把A的关联实体B也检出,则要写Hibernate.initialize(a.b)。 


Hibernate默认是用懒加载加载数据的,比如Student对象里面有个Class对象,那么我查询Student的时候,并不会查出Class对象(如果使用懒加载,只会查出它的ID)。

  1. 当你在使用Class的时候(在session范围内),比如student.getClass(),它才会加载Class对象进来

  2. 通过Hibernate.initialize()静态方法进行初始化,也可以加载出Class对象


可以通过自定义注解来实现List<String>的正则表达式Hibernate验证。下面是一个简单的示例: ```java import javax.validation.Constraint; import javax.validation.Payload; import java.lang.annotation.*; @Documented @Constraint(validatedBy = RegexListValidator.class) @Target({ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) public @interface RegexList { String message() default "list elements do not match the regex"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; String value(); } ``` 在上述示例中,我们使用了Hibernate Validator提供的注解 `@Constraint` 和 `@Documented`,并指定了注解的验证器 `RegexListValidator`。该注解包含一个属性 `value`,用于指定正则表达式。在 `RegexListValidator` 类中,我们实现了注解的验证逻辑。 下面是 `RegexListValidator` 类的示例代码: ```java import javax.validation.ConstraintValidator; import javax.validation.ConstraintValidatorContext; import java.util.List; public class RegexListValidator implements ConstraintValidator<RegexList, List<String>> { private String regex; @Override public void initialize(RegexList constraintAnnotation) { this.regex = constraintAnnotation.value(); } @Override public boolean isValid(List<String> value, ConstraintValidatorContext context) { if (value == null) { return true; } for (String str : value) { if (!str.matches(regex)) { return false; } } return true; } } ``` 在 `RegexListValidator` 类中,我们实现了 `ConstraintValidator<RegexList, List<String>>` 接口,并重写了其中的 `isValid` 方法,该方法用于实现注解的验证逻辑。在 `isValid` 方法中,我们首先判断传入的 List 是否为 null,如果是,则返回 true,表示验证通过;否则,对 List 中的每个元素进行正则表达式验证。 使用时,我们只需要在需要进行List<String>类型字段的正则表达式验证的实体类中,使用 `@RegexList` 注解标记该字段,例如: ```java public class MyClass { @RegexList("\\d+") private List<String> list; } ``` 在需要进行验证的时候,只需要调用 `validate` 方法即可,例如: ```java ValidatorFactory factory = Validation.buildDefaultValidatorFactory(); Validator validator = factory.getValidator(); MyClass obj = new MyClass(); obj.list = Arrays.asList("123", "456", "789"); Set<ConstraintViolation<MyClass>> violations = validator.validate(obj); System.out.println(violations.isEmpty()); // 输出:true,因为所有的字符串都是数字 ``` 在上述示例中,我们使用了 Hibernate Validator 提供的 `Validator` 接口来进行验证。如果验证通过,`validate` 方法将返回一个空的 `Set`,否则,该 `Set` 将包含所有的验证错误信息。 希望这个示例可以帮助您解决问题。如果您还有其他问题,请随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值