前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringDataJPA+EasyUi实现CRUD操作

SpringDataJPA+EasyUi实现CRUD操作

作者头像
xiangzhihong
发布2022-11-30 10:53:39
3780
发布2022-11-30 10:53:39
举报
文章被收录于专栏:向治洪

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:\Users\Administrator.PC-20170926MZYF\Desktop\mysql-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-generator\src\main\java" />
        <sqlMapGenerator targetPackage="mybatis"
            targetProject="springboot_mybatis-generator\src\main\resources" />
        <javaClientGenerator targetPackage="com.shyroke.mapper"
            targetProject="springboot_mybatis-generator\src\main\java" 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;
    }

}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-03-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Spring Data JPA
  • 项目构建
    • pom.xml
      • application.yml
        • generatorConfig.xml
          • Dao
            • Service
              • Control层
              相关产品与服务
              对象存储
              对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档