SpringBoot整合JPA项目实战
  JMz8bAJYIKmC 2023年12月10日 20 0


🎈个人公众号:🎈 :✨✨ 可为编程 ✨✨ 🍟🍟
🔑个人信条:🔑知足知不足 有为有不为 为与不为皆为可为🌵
🍉本篇简介:🍉 本片详细说明了SpringBoot整合JPA项目实战使用规则和注意要点,并给出具体操作实例,如有出入还望指正。

关注公众号【可为编程】回复【面试】领取年度最新面试题大全!!!

解读SpringBoot整合持久层技术之搭建并整合Spring Data JPA项目实战

接下来这阵子就SpringBoot整合持久层技术进行一个项目的搭建,做一个练手,以前搞过但是都淡忘了,特意来总结一下。今天是JPA,后面陆续搭建MyBatis、JdbcTemplate等持久层技术,供大家相互学习。

创建SpringBoot项目

直接上图吧

SpringBoot整合JPA项目实战_jpa


SpringBoot整合JPA项目实战_spring boot_02


在SQL里选择了Spring Data JPA MySql Driver Template Engines 选择 Thymeleaf

关注公众号【可为编程】回复【面试】领取年度最新面试题大全!!!

SpringBoot整合JPA项目实战_spring_03


SpringBoot整合JPA项目实战_java_04


创建成功后就是这样的一个项目结构:

SpringBoot整合JPA项目实战_mysql_05


首先创建一个mysql数据库 创建一个名为book的数据库,里面可以为空,因为JPA会帮我们自动根据实体来进行表的创建。

关注公众号【可为编程】回复【面试】领取年度最新面试题大全!!!

pom.xml文件

创建成功后我们的pom.xml如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.1.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example.springboot</groupId>
    <artifactId>jpa</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>jpa</name>
    <description>Demo project for Spring Boot JPA</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.9</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</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>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

接下来就是在项目中配置相关的数据库,在这里我们采用的是properties 有的同学可以用yml文件来进行配置,二者都是一样的。想用哪个都是一样的,至于二者有什么不同等我再写一个文章吧。

在这里我们采用了阿里的Druid,别问为什么,就是很好用,记得加上&serverTimezone=UTC这句,否则数据库链接报错。

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.url=jdbc:mysql://localhost:3306/book?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root
#是否在控制台打印输出的sql语句
pring.jpa.show-sql=true
spring.jpa.database=mysql
#表示项目在启动时根据实体类来进行数据库表的更新
spring.jpa.hibernate.ddl-auto=update
#表示使用的数据库方言是MySQL57Dialect
#spring.jpa.hibernate.naming.physical-strategy=org.hibernate.dialect.MySQL57Dialect
创建实体

省略get和se方法了,自己加上。

@Entity(name = "bookinfo")
public class Book {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    @Column(name = "name",nullable = false)
    private String name;
    @Column(name = "author",nullable = false)
    private String author;
    @Column(name = "price",nullable = true)
    private Float price;

    @Transient
    private String description;
  }
创建一个BookDao的接口
/**
 * @program: jpa
 * @description: 这是一个BOOKDao接口
 * @author: zjc
 **/

public interface BookDao extends JpaRepository<Book,Integer> {

    List<Book> getBooksByAuthorStartingWith(String author);

    List<Book> getBooksByPriceGreaterThan(Float price);

    @Query(value = "select * from bookinfo where id=(select max(id) from bookinfo)",nativeQuery = true)
    Book getMaxIdBook();

    @Query("select b from bookinfo b where b.id>:id and b.author=:author")
    List<Book> getBookByIdAndAuthor(@Param("id") Integer id,@Param("author") String author);

    @Query("select b from bookinfo b where b.id<?1 and b.name like %?2%")
    List<Book> getBookByIdAndName(@Param("id") Integer id,@Param("name") String name);
}

一定要注意sql语句传递参数的顺序,这里的?1和?2就是表示传参数的顺序。
关注公众号【可为编程】回复【面试】领取年度最新面试题大全!!!

创建BookService业务逻辑层
/**
 * @program: jpa
 * @description: 这是一个BOOKsERVICE
 * @author: zjc
 **/
@Service
public class BookService {
    @Autowired
    BookDao bookDao;
    public void addBook(Book book){
        bookDao.save(book);
    }
    public Page<Book> getBookByPage(Pageable pageable){
        return bookDao.findAll(pageable);
    }

    public List<Book> getBooksByAuthorStartingWith(String author){
        return bookDao.getBooksByAuthorStartingWith(author);
    }
    public List<Book> getBooksByPriceGeneraterThan(Float price){
        return bookDao.getBooksByPriceGreaterThan(price);
    }
    public Book getMaxIdBook(){
        return bookDao.getMaxIdBook();
    }
    public List<Book> getBookIdAndAuthor(Integer id,String author){
        return bookDao.getBookByIdAndAuthor(id,author);
    }
    public List<Book> getBooksByIdAndName(Integer id,String name){
        return bookDao.getBookByIdAndName(id,name);
    }
}

最后我们创建一个controller层进行测试。

创建Controller控制层
/**
 * @program: jpa
 * @description: 这是一个简单的BookController
 * @author: zjc
 **/
@RestController
public class BookController {

    @Autowired
    BookService bookService;
    @GetMapping("/findAll")
    public void findAll(){
        PageRequest pageable = PageRequest.of(2,3);
        Page<Book> page = bookService.getBookByPage(pageable);
        System.out.println("总页数----------:"+page.getTotalPages());
        System.out.println("总记录数----------:"+page.getTotalElements());
        System.out.println("查询结果----------:"+page.getContent());
        System.out.println("当前页数----------:"+(page.getNumber()+1));
        System.out.println("当前页记录数----------:"+page.getNumberOfElements());
        System.out.println("每页记录数----------:"+page.getSize());

    }
    @GetMapping("/search")
    public void search(){
        List<Book> ba1 = bookService.getBookIdAndAuthor(1,"鲁迅");
        List<Book> ba2 = bookService.getBooksByAuthorStartingWith("鲁");
        List<Book> ba3 = bookService.getBooksByIdAndName(2,"朝");
        List<Book> ba4 = bookService.getBooksByPriceGeneraterThan(30F);
        Book b = bookService.getMaxIdBook();
        System.out.println("ba1"+ba1);
        System.out.println("ba2"+ba2);
        //System.out.println("ba3"+ba3);
        System.out.println("ba4"+ba4);
        System.out.println("b"+b);
    }
    @GetMapping("/save")
    public void save(){
        Book book = new Book();
        book.setAuthor("鲁迅");
        book.setName("狂人日记");
        book.setPrice(23F);
        bookService.addBook(book);
    }

到这里就结束啦,整个项目结构就搭建完毕,大家可以结合自己的业务需求进行代码的继续进展和开发啦,搭建成功后的项目结构如图所示:

SpringBoot整合JPA项目实战_java_06


后面我会附上我的项目源码链接地址 SpringBoot整合持久层技术之搭建并整合Spring Data JPA项目,方便大家进行下载,如果喜欢就点个赞吧,不胜感激哟!!


欢迎大家关注【可为编程】,成长,进步,编程,技术、掌握更多知识!

SpringBoot整合JPA项目实战_spring_07


【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年12月10日 0

暂无评论

推荐阅读
JMz8bAJYIKmC