SpringBoot之使用jpa/hibernate
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
最新文章
- Java开发11个过不去的梗
- Andriod SDK Manager 安装问题解决方法
- (置顶)js实现超过页面一屏后,点击图标滚动到页面顶部top
- JSON日期格式处理
- 配置visual studio code进行asp.net core rc2的开发(转载jeffreywu)
- appcms SSRF 绕过漏洞[转载]
- 理解面向过程(OPP)、面向对象(OOP)、面向切面(AOP)
- 记一个jquery 无缝轮播的制作方法
- 注册Docker官网账号 注册按钮不能点
- ACM-ICPC 2017 Asia Urumqi:A. Coins(DP)
- HBuilder-svn安装与使用【原创】
- vc for python2.7
- HTML5: SVG (可缩放矢量图形)
- Linux wget命令详解
- java 字符串,字符数组,list间的转化
- python 字符和数值转换
- postman中 form-data、x-www-form-urlencoded、raw、binary的区别【转】
- hibernate 启动和辅助类实现资源的重复使用
- SpringCloud落地实践
- SOE 中调用第三方dll
热门文章
- Unity扩展编辑器五
- 中国的互联网企业逐步走向“单一企业多样化,商业生态同质化”,美国的互联网企业则会走向“单一企业专业化,商业生态多样化”:3.5星|《VUCA时代,想要成功,这些原则你一定得明白》
- 木马分析出现python语言,360的安全人员不禁感叹还有这种操作?
- Spring学习(4)IOC容器配置bean:定义与实例化
- Netty源码分析第7章(编码器和写数据)---->;第5节: Future和Promies
- IPC_Binder_java_1
- spring-boot+swagger实现WebApi文档
- UIWebView控件中 字体大小和字体样式的修改
- Sqlserver 每日订单半小时数据统计
- php 数组去重