>>分享流行的Java框架以及开源软件,对孙卫琴的《精通Spring》、《Spring Cloud Alibaba微服务开发零基础入门到实操》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 28235 个阅读者 刷新本主题
 * 贴子主题:  JPA 延迟加载Blob类型数据范例 回复文章 点赞(0)  收藏  
作者:flybird    发表时间:2019-04-19 00:40:09     消息  查看  搜索  好友  邮件  复制  引用

JPA Lob延迟加载示例

我们可以通过仅提取频繁访问的数据来优化检索实体时的性能。如果需要,可以提取剩余的数据。

当使用@Lob注释将字节数组或字符数组字段映射到数据库时,我们可以设置是否对该字段执行延迟加载。

延迟加载使应用程序运行速度更快,因为JPA只在加载字节数组或字符数组时才使用它们。

基本映射的获取类型可以配置为通过在相应的@Basic注释中指定fetch元素来延迟或急切加载。

FetchType枚举类型定义此元素的值,可以是EAGER或LAZY。
  @Basic(fetch=LAZY)
  @Lob @Column(name="PIC")
  private byte[] picture;

例子

下面的代码来自PersonDaoImpl.java。
package cn.w3cschool.common;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.TypedQuery;

import org.springframework.transaction.annotation.Transactional;

@Transactional
public class PersonDaoImpl {
  public void test() {

    Professor emp = new Professor();
    emp.setId(1);
    emp.setName("name");
    emp.setSalary(12345);
    em.persist(emp);

  }

  @PersistenceContext
  private EntityManager em;
}


以下代码来自Professor.java。
package cn.w3cschool.common;
import javax.persistence.Basic;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Lob;
import static javax.persistence.FetchType.LAZY;
@Entity

public class Professor {
  @Id
  private int id;
  private String name;
  private long salary;
  
  @Basic(fetch=LAZY)
  @Lob @Column(name="PIC")
  private byte[] picture;


  public int getId() {
      return id;
  }
  
  public void setId(int id) {
      this.id = id;
  }
  
  public String getName() {
      return name;
  }
  
  public void setName(String name) {
      this.name = name;
  }

  public long getSalary() {
      return salary;
  }

  public void setSalary(long salary) {
      this.salary = salary;
  }

  public byte[] getPicture() {
      return picture;
  }

  public void setPicture(byte[] picture) {
      this.picture = picture;
  }
  public String toString() {
      return "Employee id: " + getId() + " name: " + getName() +
      " salary: " + getSalary() + " pic: " + new String(getPicture());
  }
}


以下是数据库表。
Table Name: PROFESSOR
Row:
    Column Name: ID,
    Column Type: INTEGER:
    Column Value: 1

    Column Name: NAME,
    Column Type: VARCHAR:
    Column Value: name

    Column Name: PIC,
    Column Type: BLOB:
    Column Value: null

    Column Name: SALARY,
    Column Type: BIGINT:
    Column Value: 12345



程序猿的技术大观园:www.javathinker.net
  Java面向对象编程-->Swing组件(下)
  JavaWeb开发-->Servlet技术详解(Ⅲ)
  JSP与Hibernate开发-->映射一对多关联关系
  Java网络编程-->Socket用法详解
  精通Spring-->虚拟DOM和render()函数
  Vue3开发-->虚拟DOM和render()函数
  福利:Spring Cloud Alibaba微服务开发零基础入门到实操-经典...
  超全Redis命令总结,墙裂建议收藏,说不定就用上了呢
  Rust学习笔记 | 异步代码的几种写法
  深入理解spring注解之@ComponentScan注解
  说一下Spring @Autowired 注解自动注入流程
  卫琴姐姐制作的最新视频课程:基于Spring的JavaWeb开发技术详...
  Spring MVC实现国际化的几种方式
  springMVC:HandlerInterceptor拦截器的使用
  重新理解响应式编程
  Spring Data JPA详解
  Spring MVC中Controller的用法
  RabbitMQ的用途、原理以及配置
  spring源码阅读环境(几分钟下载包)
  vue项目编译75%时很慢的解决办法
  Spring MVC:切面的应用
  更多...
 IPIP: 已设置保密
楼主      
该用户目前不在线 nihaota 
  
威望: 0
级别: 新手上路
魅力: 1315
经验: 1315
现金: 2944
发文章数: 243
注册时间: 0001-01-01
 消息  查看  搜索  好友  邮件  复制  引用


讨债公司
发文章时间 2022-10-28 21:22:59
 IPIP: 已设置保密 1 楼     
1页 1条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。