首先创建项目中要选择的一些配置:
data:image/s3,"s3://crabby-images/63faf/63faf41a4dd24321d922d2027ed34b84a226f873" alt=""
data:image/s3,"s3://crabby-images/a4f2b/a4f2b9ed46032f83e5a0a4cc8d782c6a7cfd5073" alt=""
项目中配置文件配置数据库连接参数和jpa配置
#数据库,启动项目需要通过配置连接数据库
spring.datasource.url=jdbc:mysql://localhost:3306/demo?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=true
#数据库用户名和密码
spring.datasource.username=root
spring.datasource.password=xxxxxxxx
#mysql驱动类,com.mysql.cj.jdbc.Driver是mysql-connect-java6的,com.mysql.jdbc.Driver是mysql-connector-java5的
#使用前者需要指定serverTimezone,如果设定serverTimezone=UTC,会比中国时间早8个小时,可以配置serverTimezone=Shanghai
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#配置自动更新,让表数据会跟随entity类的变化而变化
spring.jpa.properties.hibernate.hbm2ddl.auto=update
#sql方言
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
#开启sql打印方便调试
spring.jpa.show-sql=true
#开启sql格式化方便展示
spring.jpa.properties.hibernate.format_sql=true
关联entity和数据库表:
1.idea连接数据库
data:image/s3,"s3://crabby-images/3fcaf/3fcafa375b29fe2e722fd2b5eb9175cfb0ed6142" alt=""
data:image/s3,"s3://crabby-images/fc53d/fc53dd884c717d6f947e3cde010c394712416472" alt=""
2.idea支持jpa
data:image/s3,"s3://crabby-images/aa985/aa9854f300e73d3676ebc7fcc9888509fe3cf576" alt=""
data:image/s3,"s3://crabby-images/84f74/84f74114c5b6c9c055ace7abab405754df392e3a" alt=""
完成后idea左边就会多出这样的菜单
data:image/s3,"s3://crabby-images/365d3/365d377449389955f17551026f68c7a1e85863f2" alt=""
关联上数据库
data:image/s3,"s3://crabby-images/1ab4f/1ab4f6ce397863bfcc2201dfa3f2035fa74dda2f" alt=""
data:image/s3,"s3://crabby-images/40c56/40c56084849a0db37ba6f4f39fb5eda404f1be48" alt=""
如果想使用jpa反向生成entity
先创建entity包
data:image/s3,"s3://crabby-images/deb9c/deb9c240167a4ec5fc12a8afe739724305c874e8" alt=""
data:image/s3,"s3://crabby-images/3894f/3894fb578bf4423a6e632700e115c8f72b3d6931" alt=""
data:image/s3,"s3://crabby-images/56391/56391ce957c5c2a3595c635be4f21b2a8e32aa11" alt=""
这时entity包中会多一个创建好的user实体类
data:image/s3,"s3://crabby-images/b6c58/b6c586ccf683ba20460ca1aebc454c3195717c93" alt=""
repository:
创建repository并继承JpaRepository,常规单表操作不需要手动实现
data:image/s3,"s3://crabby-images/d5f63/d5f63bd8991da12d3c48afa3b942a77625febcf0" alt=""
如果需要自定义查找,比如根据name查询结果:
data:image/s3,"s3://crabby-images/c5366/c5366be202e8aec58ecc2b63269e997f03a7c896" alt=""
不使用框架反向生成entity,通过写实体类动态生成数据库表
data:image/s3,"s3://crabby-images/1ac32/1ac32bc5212fa312e10867aea5c489d742e218ea" alt=""
只要启动application就会自动创建表
data:image/s3,"s3://crabby-images/8e5bf/8e5bfb4d5daf1beb851920121db48aa463b4e76f" alt=""
jpa增删改查###
jpaRepository自带方法:如果表中有对应数据就更新,没有则新增
data:image/s3,"s3://crabby-images/d9f86/d9f86064d098833cb319ee350fe2b1cc01ed5443" alt=""
jpa单表查询关键字拼凑方法###
在repository中可以根据以下规则自定义实现单表查询操作
data:image/s3,"s3://crabby-images/0f917/0f917bf0cf6d82ca60ae9363d969bf02d6272862" alt=""
data:image/s3,"s3://crabby-images/e4b0a/e4b0a06f56e923377cbd9265a438213bc96439d1" alt=""
网友评论