整合常用技术框架之 JPA 和 Redis

本文介绍了如何在微服务开发中整合Spring Data JPA与Redis。详细步骤包括添加依赖、配置文件,展示了JPA的实体类、持久层接口和方法映射到SQL的规则,以及如何使用JPA实现排序和分页。同时,文章还讲解了安装Redis的过程,并展示了Spring Boot整合Redis的操作,包括存取数据的接口实现,以及如何利用Redis的发布订阅功能提高异步处理的效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

整合 Spring Data JPA

首先,添加依赖,代码如下:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>

然后,添加配置文件,代码如下:

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/test?useSSL=false
    username: root
    password: root
    ##初始化连接数
    initialSize: 5
    ##最小连接数
    minIdle: 5
    ##最大连接数
    maxActive: 20
  jpa:
    hibernate:
      ddl-auto: update
    show-sql: true

spring.jpa.hibernate.ddl-auto 属性可以取以下值,其含义如下:

  • create:每次加载 Hibernate 时都会删除上一次生成的表,然后根据你的实体类再重新生成新表;
  • create-drop:每次加载 Hibernate 时根据实体类生成表,但是 sessionFactory 一关闭,表就自动删除;
  • update:最常用的属性(推荐属性),第一次加载 Hibernate 时根据实体类会自动建立起表的结构(前提是先建立好数据库),以后加载 Hibernate 时根据实体类自动更新表结构。即使表结构改变了,但表中的行仍然存在,不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,要等应用第一次运行起来后才会创建;
  • validate:每次加载 Hibernate 时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但会插入新值。

接着,我们添加实体类,代码如下:

@Table(name = "user")
@Entity
public class User {
    @Id
    @Column(name = "id")
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;

    @Column(name = "user_name",length = 16,nullable = false)
    private String name;

    @Column(name = "age",nullable = false)
    private Integer age;

    @Transient
    private String address;

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }
}

注意,当在实体类中定义的属性不需要映射到对应数据库表中时,只需要在实体类属性字段上添加 @transient 注解即可。

Spring Boot 整合 JPA 访问数据库非常方便,这也是其被广泛用于操作数据库的主要原因。开发过程中,通常我们会直接继承 JpaRepository 接口实现对数据库表的操作。继承该接口,操作数据库时,只需要让接口中定义的方法名称满足一定的规则,JPA 框架便能根据方法名自动解析产生 SQL 语句。示例代码如下:

public interface UserRepository extends JpaRepository<User,Integer> {
    User findByName(String name);
}

如上定义的 findByName 方法经过 JPA 框架解析之后,会自动生成一条按照用户名称查询用户的 SQL 语句,并发送到数据库执行查询操作。

编写 userService 接口和实现类:

public interface IUserService {
    User queryUserByName(String name);

    void addUser(User user);
}

@Service("userService")
public class UserServiceImpl implements IUserService {
    @Autowired
    private UserRepository userDao;

    @Override
    public User queryUserByName(String name) {
        return userDao.findByName(name);
    }

    @Override
    public void addUser(User user) {
        userDao.save(user);
    }
}

编写 Controller:

@RestController
@RequestMapping(value = &#
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值