Springboot整合使用JPA进行增删改查

ゝ一世哀愁。 2024-04-06 12:05 145阅读 0赞

Springboot整合使用JPA进行增删改查

一、添加maven依赖

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-data-jpa</artifactId>
  4. </dependency>

二、创建数据库表t_user

在这里插入图片描述

  1. CREATE TABLE `t_user` (
  2. `id` bigint NOT NULL AUTO_INCREMENT,
  3. `username` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '用户',
  4. `password` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '密码',
  5. PRIMARY KEY (`id`)
  6. ) ENGINE=InnoDB AUTO_INCREMENT=131 DEFAULT CHARSET=utf8mb3;

三、yaml文件配置

  1. #MySql8.0
  2. spring:
  3. datasource:
  4. driverClassName: com.mysql.cj.jdbc.Driver
  5. url: jdbc:mysql://localhost:3306/order_system?useSSL=false&characterEncoding=utf-8&useUnicode=true&serverTimezone=Asia/Shanghai
  6. username: root
  7. password: 123456
  8. #JPA配置
  9. jpa:
  10. hibernate:
  11. #更新或创建表结构
  12. ddl-auto: update
  13. #控制台显示sql
  14. show-sql: true

四、创建实体类TUser

  1. import lombok.Getter;
  2. import lombok.Setter;
  3. import lombok.ToString;
  4. import javax.persistence.*;
  5. @Entity
  6. @Table(name = "t_user")
  7. @Setter
  8. @Getter
  9. @ToString
  10. public class TUser {
  11. @Id
  12. @GeneratedValue(strategy = GenerationType.IDENTITY)//配置主键的生成策略
  13. @Column(name = "id") //指定和表中id字段的映射关系
  14. private Integer id;
  15. @Column(name = "username") //指定和表中username字段的映射关系
  16. private String username;
  17. @Column(name = "password") //指定和表中password字段的映射关系
  18. private String password;
  19. }

五、编写DAO层extends CrudRepository

  1. import com.example.domain.TUser;
  2. import org.springframework.data.repository.CrudRepository;
  3. @Repository
  4. public interface TUserRepository extends CrudRepository<TUser,Integer> {
  5. }

六、编写controller层测试增删改查

1、增加save

  1. @RestController
  2. public class TUserController {
  3. @Autowired
  4. private TUserRepository tUserRepository;
  5. @PostMapping("/addTUser")
  6. public String addTUser(@RequestBody TUser tUser){
  7. tUserRepository.save(tUser);
  8. return "SUCCESS";
  9. }

postman测试:

在这里插入图片描述

2、删除deleteById

  1. @RestController
  2. public class TUserController {
  3. @Autowired
  4. private TUserRepository tUserRepository;
  5. @DeleteMapping("/deleteTUser")
  6. public String deleteTUser(Integer id) {
  7. tUserRepository.deleteById(id);
  8. return "SUCCESS";
  9. }
  10. }

postman测试:

在这里插入图片描述

3、查询findById

  1. @RestController
  2. public class TUserController {
  3. @Autowired
  4. private TUserRepository tUserRepository;
  5. @GetMapping("/getUser")
  6. public Optional<TUser> getUser(Integer id) {
  7. return tUserRepository.findById(id);
  8. }
  9. }

postman测试:

在这里插入图片描述

4、自定义查询

JPA可以根据不同的查询条件在DAO层接口中自定义查询。
比如:定义一个根据id和username为查询条件的方法。

  1. import com.example.domain.TUser;
  2. import org.springframework.data.repository.CrudRepository;
  3. @Repository
  4. public interface TUserRepository extends CrudRepository<TUser,Integer> {
  5. TUser findTUserByIdAndUsername(Integer id,String username);
  6. }

controller层调用:

  1. @RestController
  2. public class TUserController {
  3. @Autowired
  4. private TUserRepository tUserRepository;
  5. @GetMapping("/getTuser")
  6. public TUser getTuser(@RequestParam Integer id,@RequestParam String username){
  7. return tUserRepository.findTUserByIdAndUsername(id,username);
  8. }
  9. }

postman测试:

在这里插入图片描述

5、修改

注意:

在使用JPA中,发现JPA实现了一些方法,如find,save等,但是没有update。如果想通过JPA进行修改,可以通过以下两种方式:

  1. 使用@Query,编写nativeSQL,通过原生的SQLupdate。优点,可以自己定制,缺点,SQL语句繁琐,不灵活,不能实现动态更改某个属性。

在DAO层接口定义update方法:

注意:

①写update原生sql语句,与查询语句的注解不同,除了@Query,还需要两个额外注解 @Modifying@Transactional

②SQL语句用了具名参数,在方法中用@Param注解与其映射

  1. import org.springframework.data.jpa.repository.Modifying;
  2. import org.springframework.data.jpa.repository.Query;
  3. import org.springframework.data.repository.CrudRepository;
  4. import org.springframework.data.repository.query.Param;
  5. import org.springframework.transaction.annotation.Transactional;
  6. @Repository
  7. public interface TUserRepository extends CrudRepository<TUser, Integer> {
  8. @Modifying
  9. @Transactional
  10. @Query(value = "UPDATE T_USER SET USERNAME = :username WHERE ID = :id", nativeQuery = true)
  11. void updateTUser(@Param("username") String username, @Param("id") int id);
  12. }

controller层调用:

注意:

调用update方法传入参数的顺序要和定义方法传入参数的顺序一致。

  1. @RestController
  2. public class TUserController {
  3. @Autowired
  4. private TUserRepository tUserRepository;
  5. @PutMapping("/updTUser")
  6. public String updTUser(@RequestParam String username,@RequestParam Integer id){
  7. tUserRepository.updateTUser(username,id);
  8. return "SUCCESS";
  9. }
  10. }

postman测试:
在这里插入图片描述

  1. 其实save方法中JPA已经对update做了处理,save方法可以看做saveOrUpdate。

发表评论

表情:
评论列表 (有 0 条评论,145人围观)

还没有评论,来说两句吧...

相关阅读