Springboot版本是2.1.3.RELEASE
  
  1、依赖
  
  List-1.1
  
  <dependency>
  
  <groupId>org.springframework.boot</groupId>
  
  <artifactId>spring-boot-starter-jdbc</artifactId>
  
  </dependency>
  
  <dependency>
  
  <groupId>org.springframework.boot</groupId>
  
  <artifactId>spring-boot-starter-data-jpa</artifactId>
  
  </dependency>
  
  <dependency>
  
  <groupId>mysql</groupId>
  
  <artifactId>mysql-connector-java</artifactId>
  
  <version>5.1.47</version>
  
  </dependency>
  
  <dependency>
  
  <groupId>org.springframework.boot</groupId>
  
  <artifactId>spring-boot-starter-web</artifactId>
  
  </dependency>
  
  <dependency>
  
  <groupId>org.springframework.boot</groupId>
  
  <artifactId>spring-boot-starter-test</artifactId>
  
  <scope>test</scope>
  
  </dependency>
  
  <dependency>
  
  <groupId>org.projectlombok</groupId>
  
  <artifactId>lombok</artifactId>
  
  <version>1.18.2</version>
  
  </dependency>
  
  2、项目整体结构
  
  图2.1
  
  bootstrap.yml内容如下,我们不需要手动创建数据库表,jpa/hiberate会自动会为我们创建的
  
  server:
  
  port: 9092
  
  servlet:
  
  context-path: /serviceB
  
  spring:
  
  application:
  
  name: cat-service-b
  
  datasource:
  
  type: com.zaxxer.hikari.HikariDataSource
  
  driver-class-name: com.mysql.jdbc.Driver
  
  username: root
  
  password: ******
  
  url: jdbc:mysql://pig-mysql:3306/cat?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowMultiQueries=true
  
  database: mysql
  
  hibernate:
  
  ddl-auto: update
  
  naming:
  
  physical-strategy: org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy
  
  show-sql: true
  
  properties:
  
  hibernate:
  
  format_sql: true
  
  physical-strategy的值为org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy,那么当实体的属性为驼峰结构时,对应到数据库表的字段上,会用"_"隔开。
  
  3、代码详解
  
  List-3.1 BaseEntity的内容,所有的实体都要继承这个类
  
  import lombok.Data;
  
  import org.springframework.data.annotation.CreatedBy;
  
  import org.springframework.data.annotation.CreatedDate;
  
  import org.springframework.data.annotation.LastModifiedDate;
  
  import javax.persistence.GeneratedValue;
  
  import javax.persistence.GenerationType;
  
  import javax.persistence.Id;
  
  import javax.persistence.MappedSuperclass;
  
  import java.util.Date;
  
  @Data
  
  @MappedSuperclass
  
  public class BaseEntity {
  
  @Id
  
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  
  protected Integer id;
  
  /** 创建人 */
  
  @CreatedBy
  
  protected String creator;
  
  /** 创建时间 */
  
  @CreatedDate
  
  protected Date createDate;
  
  /** 更新时间,默认是当前时间 */
  
  @LastModifiedDate
  
  protected Date updateDate = new Date();
  
  /** 状态 0 表示删除, 1表示可操作 */
  
  protected Integer status = 1;
  
  public BaseEntity() {
  
  if (null == this.id && null == this.createDate) {
  
  this.createDate = new Date();
  
  }
  
  }
  
  }
  
  List-3.2 User的内容
  
  import lombok.Data;
  
  import lombok.ToString;
  
  import org.hibernate.annotations.SQLDelete;
  
  import org.hibernate.annotations.Where;
  
  import javax.persistence.Entity;
  
  import javax.persistence.Table;
  
  @Data
  
  @ToString
  
  @Entity
  
  @Table(name = "cat_user")
  
  @SQLDelete(sql = "update cat_user set status = 0 where id = ?")
  
  @Where(clause = "status <> 0")
  
  public class User extends BaseEntity{
  
  private String name;
  
  private Integer age;
  
  }
  
  List-3.3 UserRepository的内容
  
  import com.mjduan.project.catserviceb.entity.User;
  
  import org.springframework.data.repository.CrudRepository;
  
  public interface UserRepository extends CrudRepository<User, Integer> {
  
  }
  
  List-3.4 UserController的内容
  
  import com.mjduan.project.catserviceb.entity.User;
  
  import com.mjduan.project.catserviceb.repository.UserRepository;
  
  import lombok.extern.slf4j.Slf4j;
  
  import org.springframework.beans.factory.annotation.Autowired;
  
  import org.springframework.web.bind.annotation.GetMapping;
  
  import org.springframework.web.bind.annotation.PathVariable;
  
  import org.springframework.web.bind.annotation.RestController;
  
  import java.util.Optional;
  
  @Slf4j
  
  @RestController
  
  public class UserController {
  
  @Autowired
  
  private UserRepository userRepository;
  
  @GetMapping(value = www.dasheng178.com"/queryUser/{id}")
  
  public User queryUser(@PathVariable(value = "id") Integer id) {
  
  log.info("查询用户,id={}", id);
  
  Optional<User> optionalUser = userRepository.findById(id);
  
  User user = optionalUser.isPresent() ? optionalUser.get() : null;
  
  log.info("返回,{}", user);
  
  return user;
  
  }
  
  @GetMapping(value = "/saveUser/{name}")
  
  public User saveUser(@PathVariable(www.fengshen157.com/ value = "name") String name) {
  
  log.info("新增用户,name={}", name);
  
  User user = new User();
  
  user.setAge(20);
  
  user.setName(name);
  
  User save = userRepository.save(user);
  
  log.info("返回,{}", save);
  
  return save;
  
  }
  
  }
  
  4、验证
  
  在浏览器地址栏中输入
  
  List-4.1
  
  #保存name为Tom的用户
  
  http://localhost:9092/serviceB/saveUser/Tom
  
  #查询Id为1的用户
  
  http://localhost:9092/serviceB/queryUser/1
  
  一些思考:
  
  自动创建表结构,我们不需要手动去创建,我们修改实体的时候,系统会自动更新数据库中的表结构。
  
  所有实体都继承BaseEntity,那么每个实体对应的数据库表,在创建日期、更新日期等共有属性都同一了,这样在一定程度上便于代码理解和系统维护。
  
  5、Reference
  
  Springboot配置mysql连接的部分配置参考:https://github.com/pristinecore/springbootsample/blob/master/springbootsample/src/main/resources/database.properties
  
  格式化SQL输出的参考:https://www.yongshiyule178.com stackoverflow.com/questions/25720396/how-to-set-hibernate-format-sql-in-spring-boot

SpringBoot之使用jpa/hibernate的更多相关文章

  1. springboot 集成 jpa/hibernate

    pom.xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...

  2. SpringBoot + Jpa(Hibernate) 架构基本配置

    1.基于springboot-1.4.0.RELEASE版本测试 2.springBoot + Hibernate + Druid + Mysql + servlet(jsp) 一.maven的pom ...

  3. javaweb各种框架组合案例(六):springboot+spring data jpa(hibernate)+restful

    一.介绍 1.springboot是spring项目的总结+整合 当我们搭smm,ssh,ssjdbc等组合框架时,各种配置不胜其烦,不仅是配置问题,在添加各种依赖时也是让人头疼,关键有些jar包之间 ...

  4. 解决 Springboot Unable to build Hibernate SessionFactory @Column命名不起作用

    问题: Springboot启动报错: Caused by: org.springframework.beans.factory.BeanCreationException: Error creati ...

  5. [读书笔记] 四、SpringBoot中使用JPA 进行快速CRUD操作

    通过Spring提供的JPA Hibernate实现,进行快速CRUD操作的一个栗子~. 视图用到了SpringBoot推荐的thymeleaf来解析,数据库使用的Mysql,代码详细我会贴在下面文章 ...

  6. SpringBoot整合StringData JPA

    目录 SpringBoot整合StringData JPA application.yml User.class UserRepository.java UserController SpringBo ...

  7. SpringBoot整合SpringData JPA入门到入坟

    首先创建一个SpringBoot项目,目录结构如下: 在pom.xml中添加jpa依赖,其它所需依赖自行添加 <dependency> <groupId>org.springf ...

  8. Spring Boot + Jpa(Hibernate) 架构基本配置

    本文转载自:https://blog.csdn.net/javahighness/article/details/53055149 1.基于springboot-1.4.0.RELEASE版本测试 2 ...

  9. Springboot spring data jpa 多数据源的配置01

    Springboot spring data jpa 多数据源的配置 (说明:这只是引入了多个数据源,他们各自管理各自的事务,并没有实现统一的事务控制) 例: user数据库   global 数据库 ...

随机推荐

  1. String字符串的方法

    String字符串在Java开发中是我们常用的一种数据类型,同时String字符串也为我们提供了大量的方法.通过一些实例的练习,我们可以对String字符串的方法有一个比较清楚的了解. 有一个字符串S ...

  2. arp与rarp

  3. sqli-labs学习笔记 DAY5

    DAY 5 sqli-labs lesson 26a 闭合符号为单引号和括号,并且不回显错误,如果服务器是Linux,尝试%a0代替空格,这里尝试使用布尔型 数据库名长度:?id=1')&&a ...

  4. 2、Ansible在使用过程中出现的错误解决方法

    1.安装完成后允许命令出错 Traceback (most recent call last): File "/usr/bin/ansible", line 197, in (ru ...

  5. Centos7 zabbix 自动发现与注册

    自动发现与自动注册 自动发现: zabbix Server主动发现所有客户端,然后将客户端登记自己的小本上,缺点zabbix server压力山大(网段大,客户端多),时间消耗多. 自动注册: zab ...

  6. 分布式高并发下全局ID生成策略

    数据在分片时,典型的是分库分表,就有一个全局ID生成的问题.单纯的生成全局ID并不是什么难题,但是生成的ID通常要满足分片的一些要求:   1 不能有单点故障.   2 以时间为序,或者ID里包含时间 ...

  7. 互评Beta版本 - Hello World团队项目空天猎

    由于改组项目未提供可以直接进行安装运行的安装包或可执行文件,所以我找到了该组组长陈同学,由他根据其小组项目的功能说明书进行演示. 基于NABCD评论作品,及改进建议 每个小组评论其他小组beta发布的 ...

  8. [2019BUAA软件工程]第0次个人作业

    我 & 计算机 写在前面   撰写本博客时,笔者正就读北航计算机系大三下的软件工程课程.借由这次博客作业的机会,笔者从高考时与计算机专业结缘.大学对计算机的学习以及对未来的计划三方面进行了些许 ...

  9. 重温servlet①

    Servlet是单例的,是线程不安全的.比较灵活,但是容易会使两个线程产生错误 类由我们自己来写,对象由服务器生成,方法由服务器自己调用.   一个servletconfig对象对应着一段web.xm ...

  10. install4j 工具为java程序打包exe

    用 install4j 工具为java程序打包exe 制作人:mark 制作时间:2013-05-02 用Eclipse 将程序源码打包成jar文件. 打包jar方法我不做介绍了,相信大家都会,不会的 ...