Java for Web学习笔记(一三六)映射(12)还谈FetchType.LAZY

说明

在前面的学习中(见Java for Web学习笔记(一二七)映射(3)OneToOne),加上fetch = FetchType.LAZY的属性是集合或者Map。反映在SQL中,就是读取其他表格的信息(无论是通过join还是什么)。例如前面学习的@OneToMany、@ElementCollection。就单个表格而言,一次读取所有的列的数据,实际上在MySQL中,即使我们只是SELECT A From Table T,也是将整行数据全部读取。

但是,有这样的场景,表格中某一列的类型是blob或者text,这一列存储信息的size很大。如果我们一次读取多行,这会相当占内存,同时由于数据量大,导致网络时延增大。我们希望对这样类提供LAZY的读取方式,只有用到,采去获取。

小例子

load-time bytecode weaving

对于entity的集合或者Maps属性,Hibernate ORM可以通过proxy对接口实现来获知需要哪些数据。但是对于entity的简单属性,Hibernate需要在bytecode层面来,拦截方法的调用。这就是所谓的load-time bytecode weaving。在Spring中entityManager采用的注入方式,而注入,本身就是在bytecode层面,如果我们不能在接口实现中进行,就在bytecode层面进行处理。

具体的实现就是通过Spring的org.springframework.instrument.classloading.LoadTimeWeaver来检查并使用Tomcat的ClassLoader。我们RootContextConfiguration中加上相关的设置。

@EnableLoadTimeWeaving
......
public class RootContextConfiguration implements AsyncConfigurer, SchedulingConfigurer{
    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactoryBean(){
        ... ...
        /* 在书中给的是hibernate.ejb.use_class_enhancer = true,但我们的测试,至少在
        * hibernate 5中是不起作用的,不会真的是LAZY。在Hibernate文档(5.2)的23.6. Bytecode 
        * Enhancement Properties中给出另外一个配置:
        * hibernate.enhancer.enableLazyInitialization = true, 这个能够正常工作。 */
        properties.put("hibernate.enhancer.enableLazyInitialization","true");
        ... ...
    }
    ... ...
}

相关的entity代码

可以直接在Entity相关属性上面加上LAZY的说明,下面是某个例子:

//因为@Lob是没有fetch参数的,因此在@Basic中定义
@Lob @Basic(fetch = FetchType.LAZY)
public byte[] getContents() {
	return contents;
}

除了entity的直接属性外,还可以用到@OneToOne和@ManyToOne,或者是集合和Map属性内的元素。

对于XML和JSON要注意

如果这个entity类需要封装为XML或者JSON在接口传递(一般不建议这样,因为那属于呈现层,不因和数据存储的接口相绑定)。但是如果有这种情况,使用了load-time bytecode weaving就需要注意了,在这个过程中,Hibernate可能会在类加入一些不可以预测的属性或方法。这会影响到XML和JSON的翻译。我们可以在类中标识不自动进行XML或者JSON的转换,除非对属性明确标识。下面是例子:

@Entity
@XmlRootElement(name = "attachment")
@XmlAccessorType(XmlAccessType.NONE)
@JsonAutoDetect(creatorVisibility = JsonAutoDetect.Visibility.NONE,
        fieldVisibility = JsonAutoDetect.Visibility.NONE,
        getterVisibility = JsonAutoDetect.Visibility.NONE,
        isGetterVisibility = JsonAutoDetect.Visibility.NONE,
        setterVisibility = JsonAutoDetect.Visibility.NONE)
public class Attachment implements Serializable{
	......

	@Basic
	@Column(name = "AttachmentName")
	@XmlElement
	@JsonProperty
	public String getName() {
		return name;
	}

	@Lob @Basic(fetch = FetchType.LAZY)
//	@LazyGroup是hibernate提供的标记,不是标准的JPA。当读的时候,会将lazy的相关属性都读入。
//	如果需要区分,某次只读入某个或某些属性,可以使用@LazyGroup进行区分,没有标记就是default了。
//	@LazyGroup( "lobs" )
	@XmlElement
	@XmlSchemaType(name = "base64Binary")
	@JsonProperty
	public byte[] getContents() {
		return contents;
	}
	... ...
}

相关链接:我的Professional Java for Web Applications相关文章

 

OpenVINO计算机视觉—实例实战

11-02
手把手讲授如何搭建成功OpenVINO框架,并且使用预训练模型快速开发超分辨率、道路分割、汽车识别、人脸识别、人体姿态和行人车辆分析。得益于OpenVINO框架的强大能力,这些例子都能够基于CPU达到实时帧率。 课程的亮点在于在调通Demo的基础上更进一步:一是在讲Demo的时候,对相关领域问题进行分析(比如介绍什么是超分辨率,有什么作用)、预训练模型的来龙去脉(来自那篇论文,用什么训练的)、如何去查看不同模型的输入输出参数、如何编写对应的接口参数进行详细讲解;二是基本上对所有的代码进行重构,也就是能够让例子独立出来,并且给出了带有较详细注释的代码;三是注重实际运用,将Demo进一步和实时视频处理框架融合,形成能够独立运行的程序,方便模型落地部署;四是重难点突出、注重总结归纳,对OpenVINO基本框架,特别是能够提高视频处理速度的异步机制和能够直接部署解决实际问题的骨骼模型着重讲解,帮助学习理解;五是整个课程准备精细,每一课都避免千篇一律,前一课有对后一课的预告,后一课有对前一课的难点回顾,避免学习过程中出现突兀;六是在适当的时候拓展衍生,不仅讲OpenVINO解决图像处理问题,而且还补充图像处理的软硬选择、如何在手机上开发图像处理程序等内容,帮助拓展视野,增强对行业现状的了解。 基本提纲: 1、课程综述、环境配置 2、OpenVINO范例-超分辨率(super_resolution_demo) 3、OpenVINO范例-道路分割(segmentation_demo) 4、OpenVINO范例-汽车识别(security_barrier_camera_demo) 5、OpenVINO范例-人脸识别(interactive_face_detection_demo) 6、OpenVINO范例-人体姿态分析(human_pose_estimation_demo) 7、OpenVINO范例-行人车辆分析(pedestrian_tracker_demo) 8、NCS和GOMFCTEMPLATE 9、课程小结,资源分享
©️2020 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值