SpringData Jpa(1)SpringDataJpa入门

本文介绍了SpringData Jpa的入门知识,包括maven依赖和yml配置,讲解了ddl-auto的各种模式。接着讨论了实体类的注解,如@Entity、@Table、@Id和@GeneratedValue。还介绍了JpaRepository接口的主要方法,如delete、findOne、findAll等,并展示了如何创建repository。最后,文章详细阐述了Example查询机制,包括Probe、ExampleMatcher和Example的组成以及ExampleMatcher的使用方法。
摘要由CSDN通过智能技术生成

一、SpringData Jpa 入门

  • maven依赖相关配置
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-data-jpa</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-jdbc</artifactId>
</dependency>
  • yml 相关配置
server:
  port: 8080
  servlet:
    context-path: /
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test_jpa?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&useSSL=false
    username: root
    password: 123456
  jpa:
    database: MySQL
    database-platform: org.hibernate.dialect.MySQL5InnoDBDialect
    show-sql: true
    hibernate:
      ddl-auto: update

ddl-auto: update

  1. create:每次运行程序时,都会重新创建表,故而数据会丢失
  2. create-drop:每次运行程序时会先创建表结构,然后待程序结束时清空表
  3. upadte:每次运行程序,没有表时会创建表,如果对象发生改变会更新表结构,原有数据不会清空,只会更新(推荐使用)
  4. validate:运行程序会校验数据与数据库的字段类型是否相同,字段不同会报错
  5. none: 禁用DDL处理
  • model 实体类

实体类中常用注解:

@Entity :声明这个类是一个实体类
@Table:指定映射到数据库的表格
@Id :映射到数据库表的主键属性,一个实体只能有一个属性被映射为主键
@GeneratedValue:主键的生成策略
@Column配置单列属性

@Entity
@Table(name ="tb_user")
@Data
public class User {
   
    @Id
    @GenericGenerator(name ="idGenerator",strategy = "uuid")
    @GeneratedValue(generator = "idGenerator")
    private String id;

    @Column(name ="username",unique= true, nullable = false, length = 64)
    private String username;

    @Column(name = "password", nullable = false,length =64)
    private String password;

    @Column(name ="email",length = 64)
    private String email;
}

主键采用UUID策略

@Gene

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值