**1. 引入`spring-boot-starter-data-jpa`**
```xml
<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>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<version>8.0.32</version>
</dependency>
```
**2. `application.yml`**
```yml
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/learnjpa?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
username: root
password: uhg</flEt3dff
driver-class-name: com.mysql.cj.jdbc.Driver
type: com.zaxxer.hikari.HikariDataSource
jpa:
#使用MySQL数据库
database: MYSQL
database-platform: org.hibernate.dialect.MySQLDialect
#控制台输出正在执行的SQL语句
show-sql: true
hibernate:
#create:每次运行程序时,都会重新创建表,故而数据会丢失
#create-drop:每次运行程序时会先创建表结构,然后待程序结束时清空表
#upadte:每次运行程序,没有表时会创建表,如果对象发生改变会更新表结构,原有数据不会清空,只会更新(推荐使用)
#validate:运行程序会校验数据与数据库的字段类型是否相同,字段不同会报错
#none: 禁用DDL处理
ddl-auto: update
```
<br/>
**3. 创建实体类**
```java
@Data
@Entity //声明实体
@Table(name = "tb_user") //实体与表建立映射关系,name就是表名
public class User implements Serializable {
/**
* @Id:主键
* strategy:主键生成策略。GenerationType.IDENTITY使用数据库的生成策略,如果是mysql就是自增键。
*/
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
/**
* @Column:属性与表字段建立映射关系。 name就是表的字段名
*/
@Column(name = "username")
private String username;
@Column(name = "password")
private String password;
@Column(name = "email")
private String email;
}
```
<br/>
**4. 创建查询接口**
```java
/**
* 1. JpaRepository<实体类,主键类型>接口:用来完成基本CRUD操作。
* 2. JpaSpecificationExecutor<实体类>:用来完成复杂的查询,如分页等查询操作。
*/
public interface UserRepository extends JpaRepository<User, Integer>, JpaSpecificationExecutor<User> {
}
```
<br/>
**5. 简单的增删改查**
>[info]JPA 可以根据实体自动建表,不需要自己手动到数据库中建表。
```java
@SpringBootTest
public class UserRepositoryTests {
@Autowired
private UserRepository userRepository;
/**
* 新增一条数据。
*/
@Test
public void save() {
User user = new User();
user.setUsername("张三");
user.setPassword("zhangsan");
user.setEmail("zhangsan@qq.com");
User result = userRepository.save(user);
System.out.println(result);
//User(id=1, username=张三, password=zhangsan, email=zhangsan@qq.com)
}
/**
* 新增与更新用的是同一个方法,如果id已经存在则是更新,否则就是新增。
*/
@Test
public void update() {
User user = new User();
user.setId(1);
user.setUsername("李四");
user.setPassword("lisi");
user.setEmail("lisi@qq.com");
User result = userRepository.save(user);
System.out.println(result);
//User(id=1, username=李四, password=lisi, email=lisi@qq.com)
}
/**
* 根据id查询
*/
@Test
public void findOne() {
Optional<User> result1 = userRepository.findById(1);
System.out.println(result1.get());
//User(id=1, username=李四, password=lisi, email=lisi@qq.com)
}
/**
* 根据id删除数据
*/
@Test
public void delete() {
userRepository.deleteById(1);
}
}
```
- Spring
- Spring是什么
- Spring与EJB对比
- Spring的组成
- 首个Spring程序
- IoC控制反转
- 什么是IoC
- IoC编程
- 依赖注入方式
- 不同变量注入
- AOP面向切面编程
- AOP思想
- AOP实现原理
- AOP关键术语
- AOP编程
- 5种增强方式
- 切入点规则
- 自动装配
- Spring注解开发
- Bean注解
- AOP注解
- 完全注解
- 配置文件拆分
- SpringBean
- Bean常用属性
- Bean作用域
- Bean生命周期
- SpringBoot
- SpringBoot是什么
- 项目创建
- 配置文件
- 配置类型
- 读取配置
- 占位符
- 多环境配置
- 配置优先级
- 更改配置文件
- 自定义IoC容器
- 常用组件
- ApplicationContextAware
- CommandLineRunner
- Boot[Web]
- 引入模板引擎
- 静态资源访问
- 指定首页
- JSP支持
- 注册拦截器
- 注册Servlet组件
- 注册Servlet
- 注册过滤器
- 注册监听器
- 拦截器与过滤器区别
- 文件上传
- 文件下载
- 变更服务器
- Controller层封装
- HttpServletRequest
- 获取请求行
- 获取请求头
- 获取请求体
- Boot[自动配置]
- 自动配置是什么
- 自动配置报告
- 关闭自动配置
- 条件注解
- Boot[场景启动器]
- 场景启动器是什么
- 自定义场景启动器
- Boot[日志]
- 日志框架
- 日志级别
- 日志配置
- 配置文件
- 切换日志
- Boot[邮件任务]
- Boot[定时任务]
- cron表达式
- 起步
- 任务并行
- 注解Scheduled参数
- Boot[异步任务]
- 起步
- 注意事项与原理
- 自定义线程池
- Boot[缓存]
- JSR107缓存技术
- Spring缓存抽象
- 缓存注解
- SpEL表达式
- 起步
- 自定义key生成器
- 工作原理
- Boot[Redis]
- 起步
- 序列化机制
- Boot[Jdbc]
- 起步
- 两个模板类
- JdbcTemplate
- 增删改
- 查询
- NamedParameterJdbcTemplate
- 增删改
- 查询
- 自定义JdbcTemplate
- Boot[JPA]
- SpringDataJPA是什么
- 与JPA、Hibernate的关系
- 起步
- SpringDataJPA原理
- 查询方式
- 方法命名规则查询
- 限制查询结果查询
- 注解Query查询
- 命名参数查询
- SpEL表达式查询
- 原生查询
- 更新与删除
- 查询指定字段
- Specification动态查询
- 分页查询与排序
- 多表查询
- 一对一查询
- 一对多查询
- 多对多查询
- Specification查询
- Query注解查询
- 主键策略
- 单独主键
- 联合主键
- 级联操作
- 加载规则
- 审计功能
- 常用注解
- 避坑指南
- Boot[JSR303]
- JSR303是什么
- 常用约束
- 起步
- 简单校验
- 嵌套校验
- 分组校验
- 自定义约束注解
- 自定义校验工具
- Spring事务
- 事务的作用
- 起步
- 事务参数
- SpringDoc文档
- SpringDoc是什么
- 起步
- 自定义配置
- 常用Doc注解
- JSR303文档
- knife4j文档
- 常用配置
- Boot[RabbitMQ]
- 起步
- Fanout交换机类型
- Direct交换机类型
- Topic交换机类型
- 延迟队列插件
- RabbitListener监听方法
- JWT认证
- 认证流程
- 起步
- 密码加密
- JWT认证实现