springBoot整合JPA

Posted 雪山上的蒲公英

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springBoot整合JPA相关的知识,希望对你有一定的参考价值。

1. 初始化项目,引入相关依赖

项目中引入的依赖关系

当中最主要的 spring-boot-starter-data-jpa 包主要依赖如下,可以看到JPA的底层主要是通过hibernate实现的。

2. 创建实体类,利用JPA生成数据表

2.1 编写实体类,配置好映射关系,从而和数据表进行映射

import javax.persistence.*;

@Entity //声明实体类,和数据表映射 @Table(name="tb_user") //指定对应数据表,省略的话默认表名为类名小写 public class User { @Id //声明为该表主键 @GeneratedValue(strategy = GenerationType.IDENTITY) //主键自增策略 private Integer id; @Column(name = "first_name",length = 50) //设置列名及长度 private String firstName; @Column private String lastName; private String address; //getter & setter 方法略

2. 编写Dao接口来操作实体类对应的数据表(Repository)

import com.zang.springboot.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;

//继承JpaRepository来完成对数据库的操作
public interface UserRepository extends JpaRepository<User,Integer>{

}

3. 配置application.yml

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/user_manage?serverTimezone=GMT%2B8
    username: root
    password: 123
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    hibernate:
    #更新或创建数据库表结构
      ddl-auto: update
    #输出执行sql
    show-sql: true

启动Application类,JPA输出如下sql语句进行表的创建

Hibernate: create table tb_user (id integer not null auto_increment, address varchar(255), first_name varchar(50), last_name varchar(255), primary key (id)) engine=MyISAM

3. 插入查询测试

新建controller来接收请求

import com.zang.springboot.entity.User;
import com.zang.springboot.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class UserController {

    @Autowired
    UserRepository userRepository;

    @GetMapping("/user/{id}")
    public User getUser(@PathVariable("id") Integer id){
        User user = userRepository.findById(id).orElse(null);
        return user;
    }

    //@PostMapping("/user")
    @GetMapping("/user") //为测试方便,通过url传参,请求应设为Get方式
    public User insertUser(User user){
        User saveUser = userRepository.save(user);
        return saveUser;
    }
}

传值测试:

后台输出如下,证明插入成功:

查询测试:

后台输出查询sql如下:

Hibernate: select user0_.id as id1_0_0_, user0_.address as address2_0_0_, user0_.first_name as first_na3_0_0_, user0_.last_name as last_nam4_0_0_ from tb_user user0_ where user0_.id=?

 

以上是关于springBoot整合JPA的主要内容,如果未能解决你的问题,请参考以下文章

springBoot整合JPA

springboot整合JPA+MYSQL+queryDSL数据增删改查

springboot整合JPA+MYSQL+queryDSL数据增删改查

springboot整合JPA+MYSQL+queryDSL数据增删改查

SpringBoot整合JDBCMybatisSpringData JPA

springboot整合JPA