SpringDataJPA+EasyUi实现CRUD操作

2022-11-30 10:53:39 浏览数 (1)

Spring Data JPA

JPA(Java Persistence API)是Sun官方提出的Java持久化规范。它为Java开发人员提供了一种对象/关联映射工具来管理Java应用中的关系数据。它的出现主要是为了简化现有的持久化开发工作和整合ORM技术。

Spring Data JPA是Spring基于Hibernate开发的一个JPA框架,Spring Data JPA 是Spring Data 的一个子项目,它通过提供基于JPA的Repository极大地减少了JPA作为数据访问方案的代码量。

项目构建

使用IntelliJ IDEA 创建SpringBoot项目,如下图:

点击Next,输入必要参数,然后选择web,MySQL,JPA组件作为我们开发必备组件,然后点击Next即可完成项目的创建,如下图:

完成后项目的结构如下图:

pom.xml

pom文件是项目构建过程中依赖的一些文件,内容如下:

代码语言:javascript复制
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.xzh.jpa</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>demo</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.0.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <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-web</artifactId>
        </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>
        </dependency>
    </dependencies>

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

application.yml

在 Spring Boot 中,有两种配置文件,一种是application.properties,另一种是application.yml,两种都可以配置Spring Boot 项目中的一些变量的定义、参数的设置等。如果采用application.yml的方式,配置如下:

代码语言:javascript复制
spring:
    datasource:
        driver-class-name:  com.mysql.jdbc.Driver
        url: jdbc:mysql://127.0.0.1:3306/jpa
        username: root
        password: 12345678

    jpa:
        hibernate:
            ddl-auto: update
            show-sql: true

如果采用application.properties方式,application.properties的配置信息需要写完整。

代码语言:javascript复制
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/dbgirl?characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root

spring.jpa.show-sql= true
spring.jpa.hibernate.ddl-auto=update
spring.jpa.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
spring.jackson.serialization.indent_output=false

generatorConfig.xml

选择File-New->generatorConfig,创建一个generatorConfig.xml文件。

当然,本项目中需要去掉自动生成的注释,所以需要将下面的字段修改为true。

代码语言:javascript复制
<property name="suppressAllComments" value="true"/>

然后需要对jdbcConnection段进行配置

代码语言:javascript复制
<jdbcConnection userId="root" password="12345678" driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/jpa"/>

如果需要使用MyBatis的字段映射功能,还需要配置具体的表选项。例如下面是一个简单的配置。

代码语言:javascript复制
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
    <classPathEntry
        location="C:UsersAdministrator.PC-20170926MZYFDesktopmysql-connector-java-5.1.40-bin.jar" />
    <context id="context1">

     <commentGenerator>
     <!-- 去掉自动生成的注释 -->
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>

        <jdbcConnection connectionURL="jdbc:mysql://localhost/db_boot"
            driverClass="com.mysql.jdbc.Driver" password="" userId="root" />
        <javaModelGenerator targetPackage="com.shyroke.bean"
            targetProject="springboot_mybatis-generatorsrcmainjava" />
        <sqlMapGenerator targetPackage="mybatis"
            targetProject="springboot_mybatis-generatorsrcmainresources" />
        <javaClientGenerator targetPackage="com.shyroke.mapper"
            targetProject="springboot_mybatis-generatorsrcmainjava" type="XMLMAPPER" />
        <table tableName="users" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false" >
        </table>
    </context>
</generatorConfiguration>

接着使用生成的generatorConfig.xml,自动生成bean、mapper、mapper xml文件。

生成的项目目录结构如下:

Dao

SpringBoot创建DAO层很多种方法其中japrepository是最强大的而且最有特色的一种,我们可以针对不同的实体创建repository接口。在SpringBoot中默认已经提供了非常多的常规CRUD操作的repository,以下就是Spring为我们提供的repository接口。

SpringBoot真的是非常体贴,大大减低了我们的工作量。我们通过继承JpaRepository接口,除了可以获得上面的基础CRUD操作方法之外,还可以通过Spring规定的接口命名方法自动创建复杂的CRUD操作,以下是我在Spring Data JPA 文档中找到的命名规则表,关于这方面的内容大家可以去下面的地址去详细了解: https://www.cnblogs.com/toSeeMyDream/p/6170790.html

Service

Service主要用于提供对外数据访问,本部分内容如下:

代码语言:javascript复制
public interface UserService {

    /**
     * 保存用户信息
     * @param tUser
     * @return
     */
    TUser save(TUser tUser);


    /**
     * 根据Id删除用户
     * @param id
     * @return
     */
    TUser deleteById(Integer id);

    /**
     * 根据Id查找用户
     * @param id
     * @return
     */
    TUser findById(Integer id);

    /**
     * 查找全部用户
     * @return
     */
    List<TUser> findAll();

    /**
     * 分页获取
     * @param pageable
     * @return
     */
    Page<TUser> findAll(Pageable pageable);
}
代码语言:javascript复制
public class UserServiceImp implements UserService {

    @Override
    public TUser save(TUser tUser) {
        return null;
    }

    @Override
    public TUser deleteById(Integer id) {
        return null;
    }

    @Override
    public TUser findById(Integer id) {
        return null;
    }

    @Override
    public List<TUser> findAll() {
        return null;
    }

    @Override
    public Page<TUser> findAll(Pageable pageable) {
        return null;
    }
}

Control层

Controller是SpringBoot里最基本的组件,他的作用是把用户提交来的请求通过对URL的匹配,分配个不同的接收器,再进行处理,然后向用户返回结果。 本例的Controller代码如下:

代码语言:javascript复制
@Controller
@RequestMapping("/user")
public class UserController {


    private UserService userService;

    //首页
    @RequestMapping("/index")
    public String index(){
        return "/user/index";
    }


    //保存用户信息
    @ResponseBody
    @RequestMapping("/save")
    public Map<String,Object> save(TUser user){
        Map<String,Object> result=new HashMap<>();
        userService.save(user);
        result.put("success", true);
        return result;
    }

    //删除用户信息
    @ResponseBody
    @RequestMapping("/delete")
    public Map<String,Object> delete(@RequestParam(value = "ids")String ids){
        Map<String,Object> result=new HashMap<>();
        String[] idsStr=ids.split(",");
        for (int i=0;i<idsStr.length;i  ){
            userService.deleteById(Integer.parseInt(idsStr[i]));
        }
        result.put("success", true);
        return result;
    }

    //查询用户列表信息
    @ResponseBody
    @RequestMapping("/list")
    public Map<String,Object> list(@RequestParam(value = "page")Integer page,
                                   @RequestParam(value = "rows")Integer rows){
        Map<String,Object> result=new HashMap<>();
        Page<TUser> list=userService.findAll(new PageRequest(page-1,rows ));
        int total=userService.findAll().size();

        result.put("total", total);
        result.put("rows", rows);
        return result;
    }

}

0 人点赞