SpringBoot+JPA

今天学习了一下JPA,发现如果只是简单的CRUD,用JPA确实要简单很多。JPA其实就相当于一个规范,他已经帮你写好了CRUD的一些实现代码,你只要实现他们,然后使用就可以了。

步骤:
  1. 在SpringBoot中导入JPA、JDBC、MySQL的依赖
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jdbc</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>


    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>compile</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
        <exclusions>
            <exclusion>
                <groupId>org.junit.vintage</groupId>
                <artifactId>junit-vintage-engine</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
</dependencies>
  1. 编写实体类
import javax.persistence.*;

@Entity //告诉JPA这是一个实体类
@Table(name = "tab_user")//指定这个实体类对应哪个表,如果不写名字的话就自动生成或对应类名全小写
public class User {
    @Id//主键
    @GeneratedValue(strategy = GenerationType.IDENTITY) // 定义主键自增类型
    private int id;

    @Column(name = "lastname") //指定该属性对应表中哪个字段
    private String name;
    private String mail; //不写的话,表中的字段名称和属性名称是一样的
  1. 编写接口,继承JpaRepository
public interface UserRepository extends JpaRepository<User,Integer>//<你要放的类型,主键的类型>{
}
  1. 在application.properties或者yml中配置
spring:
  datasource:
    username: xxx
    password: xxx
    url: jdbc:mysql://xxx?serverTimezone=UTC
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    hibernate:
      ddl-auto: update //刚开始启动,如果没有表就建表,如果实体发生更新,那么表会随着改变
    show-sql: true // 在控制台输出sql语句

5.编写响应的业务处理类

@RestController //ResponseBody+Controller,返回的数据类型为json 
public class UserController {

    @Autowired
    UserRepository userRepository;

    @GetMapping("/user/{id}")
    public User getOneUserById(@PathVariable("id") int id){
        User user = userRepository.getOne(id);//直接调用这个接口的方法就可以了
        return user;
    }

    @GetMapping("/user")
    public User insertUser(User user){
        User user1 = userRepository.save(user);
        return user1;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值