Spring-Data-Jpa入门教程(一)

一、啥是JPA?

JPA,全英文名叫Java Persistence API,就是java持久化api,是SUN公司推出的一套基于ORM的规范。

持久化想必如雷贯耳,都0202年了,谁还不用个持久化框架啊,举起mybatis。

ORM呢?全英文名为Object-Relational Mapping:对象关系映射,简单来说为了不用JDBC那一套原始方法来操作数据库,ORM框架横空出世(mybatis、hibernate等等)。

然而ORM框架出的太多了,百花齐放,琳琅满目,你一套标准我一套标准,要是想换一套框架实现项目,可能要从头再写。啊这?入土吧。

百度这样介绍SUN的JPA规范:

Sun引入新的JPA ORM规范出于两个原因:

其一,简化现有Java EE和Java SE应用开发工作;

其二,Sun希望整合ORM技术,实现天下归一。

有气魄,我喜欢,学他丫的。

二、Spring-Data-Jpa简介

学jpa哪家强?哪家简单学哪家,spring-data-jpa最简单。介绍如下:

Spring Data JPA是Spring Data家族的一部分,可以轻松实现基于JPA的存储库。 此模块处理对基于JPA的数据访问层的增强支持。 它使构建使用数据访问技术的Spring驱动应用程序变得更加容易。

总的来说JPA是ORM规范,Hibernate、TopLink等是JPA规范的具体实现,这样的好处是开发者可以面向JPA规范进行持久层的开发,而底层的实现则是可以切换的(敲黑板哦)。Spring Data Jpa则是在JPA之上添加另一层抽象(Repository层的实现),极大地简化持久层开发及ORM框架切换的成本。

也就是如下图所示:


JPA原理图

三、环境配置

话不多说,使用Maven管理包,使用springboot框架,建个空maven项目就行

1、配置pom.xml

```

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.0.4.RELEASE</version><relativePath/><!--lookup parentfromrepository--></parent><groupId>com.jacky</groupId><artifactId>user-service</artifactId><version>0.0.1-SNAPSHOT</version><name>user-service</name><description>Demo projectforSpring Boot</description><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></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>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.6.3</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.20</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency></dependencies>

```

2、配置application.yml

server:port:8801spring:application:name:user-service  datasource:type:com.alibaba.druid.pool.DruidDataSource    driverClassName:com.mysql.jdbc.Driver    url:jdbc:mysql://10.16.58.21:3306/appt_test    username:root    password:123456# druid配置项,默认spring-boot不支持,故需要config类来解析    initialSize:5minIdle:5maxActive:20maxWait:60000timeBetweenEvictionRunsMillis:60000minEvictableIdleTimeMillis:300000validationQuery:SELECT1FROM DUAL    testWhileIdle:truetestOnBorrow:falsetestOnReturn:falsepoolPreparedStatements:truemaxPoolPreparedStatementPerConnectionSize:20filters:stat,wall,log4j    connectionProperties:druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000jpa:hibernate:ddl-auto:update    show-sql:true

3、配置Springboot启动类

@SpringBootApplication@EnableJpaAuditingpublicclassUserServiceApplication{publicstaticvoidmain(String[]args){SpringApplication.run(UserServiceApplication.class,args);}@PostConstructvoidsetDefaultTimeZone(){TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));}}

注意:

除了@SpringBootApplication启动注解外,

还有一个注解@EnableJpaAuditing,它是用来启动Jpa的审计功能,比如说在使用建表中经常会加入 版本号、创建时间、修改时间 、创建者、修改者 这五个字段。因此为了简化开发, 我们可以将其交给jpa来自动填充。

4、创建阿里Druid配置类

importcom.alibaba.druid.pool.DruidDataSource;importcom.alibaba.druid.support.http.StatViewServlet;importcom.alibaba.druid.support.http.WebStatFilter;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;importorg.springframework.beans.factory.annotation.Value;importorg.springframework.boot.web.servlet.FilterRegistrationBean;importorg.springframework.boot.web.servlet.ServletRegistrationBean;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;importorg.springframework.context.annotation.Primary;importjavax.sql.DataSource;importjava.sql.SQLException;/**

* 阿里Druid配置类

*

* @author zcc ON 2018/2/11

**/@ConfigurationpublicclassDruidConfig{privatestaticfinal Logger log=LoggerFactory.getLogger(DruidConfig.class);@Value("${spring.datasource.url}")privateString dbUrl;@Value("${spring.datasource.username}")privateString username;@Value("${spring.datasource.password}")privateString password;@Value("${spring.datasource.driverClassName}")privateString driverClassName;@Value("${spring.datasource.initialSize}")privateint initialSize;@Value("${spring.datasource.minIdle}")privateint minIdle;@Value("${spring.datasource.maxActive}")privateint maxActive;@Value("${spring.datasource.maxWait}")privateint maxWait;@Value("${spring.datasource.timeBetweenEvictionRunsMillis}")privateint timeBetweenEvictionRunsMillis;@Value("${spring.datasource.minEvictableIdleTimeMillis}")privateint minEvictableIdleTimeMillis;@Value("${spring.datasource.validationQuery}")privateString validationQuery;@Value("${spring.datasource.testWhileIdle}")privateboolean testWhileIdle;@Value("${spring.datasource.testOnBorrow}")privateboolean testOnBorrow;@Value("${spring.datasource.testOnReturn}")privateboolean testOnReturn;@Value("${spring.datasource.poolPreparedStatements}")privateboolean poolPreparedStatements;@Value("${spring.datasource.maxPoolPreparedStatementPerConnectionSize}")privateint maxPoolPreparedStatementPerConnectionSize;@Value("${spring.datasource.filters}")privateString filters;@Value("{spring.datasource.connectionProperties}")privateString connectionProperties;@Bean    @PrimarypublicDataSourcedataSource(){DruidDataSource datasource=newDruidDataSource();log.info("----------- druid datasource ----------");datasource.setUrl(this.dbUrl);datasource.setUsername(username);datasource.setPassword(password);datasource.setDriverClassName(driverClassName);datasource.setInitialSize(initialSize);datasource.setMinIdle(minIdle);datasource.setMaxActive(maxActive);datasource.setMaxWait(maxWait);datasource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);datasource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);datasource.setValidationQuery(validationQuery);datasource.setTestWhileIdle(testWhileIdle);datasource.setTestOnBorrow(testOnBorrow);datasource.setTestOnReturn(testOnReturn);datasource.setPoolPreparedStatements(poolPreparedStatements);datasource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize);try{datasource.setFilters(filters);}catch(SQLExceptione){e.printStackTrace();}datasource.setConnectionProperties(connectionProperties);returndatasource;}@BeanpublicServletRegistrationBeanregistrationBean(){ServletRegistrationBean servletRegistrationBean=newServletRegistrationBean(newStatViewServlet());// 添加初始化参数:initParamsservletRegistrationBean.addUrlMappings("/druid/*");// 白名单servletRegistrationBean.addInitParameter("allow","127.0.0.1");//黑名单        servletRegistrationBean.addInitParameter("deny","192.168.0.101");//登录查看信息的账号密码.servletRegistrationBean.addInitParameter("loginUsername","admin");servletRegistrationBean.addInitParameter("loginPassword","123456");//可重置数据.servletRegistrationBean.addInitParameter("resetEnable","false");returnservletRegistrationBean;}@BeanpublicFilterRegistrationBeanfilterRegistrationBean(){FilterRegistrationBean filterRegistrationBean=newFilterRegistrationBean(newWebStatFilter());//添加过滤规则.filterRegistrationBean.addUrlPatterns("/*");// 添加不需要忽略的格式信息.filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");returnfilterRegistrationBean;}}

5、创建repository数据访问层接口,

通过repository接口可以很方便的调用JPA,完成数据库的所有操作,当然包括数据库CRUD

importcom.jacky.userservice.pojo.entity.dvUser;importorg.springframework.data.jpa.repository.JpaRepository;publicinterfacedvUserRepositoryextendsJpaRepository<dvUser,Long>{}

可以看到,这个接口继承了JpaRepository<实体,ID>,spring-data-jpa只需要这个信息,就可以帮你完成常用的操作:增删查改。

6、创建entity实体类

@Data@Entity@Table(name="dv_user")@EntityListeners(AuditingEntityListener.class)publicclassdvUser{@Id    @Column(name="id")@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="JPA_USER_S2")@SequenceGenerator(sequenceName="JPA_USER_S1",name="JPA_USER_S2",allocationSize=1)privateLong id;@Column(name="name")privateString name;@Column(name="object_version")@VersionprivateLong objectVersion;@Column(name="created_by")@CreatedByprivateString createdBy;@Column(name="created_date")@CreatedDate    @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8")privateDate createdDate;@Column(name="last_updated_by")@LastModifiedByprivateString lastUpdatedBy;@Column(name="last_updated_date")@LastModifiedDate    @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8")privateDate lastUpdatedDate;}

7、创建service接口

importcom.jacky.userservice.pojo.entity.dvUser;importjava.util.List;publicinterfacedvUserService{/**

    * 新增用户

    * @param user 用户对象

    */dvUserinsertUser(dvUser user);/**

    * 删除用户

    * @param id 删除id

    */voiddeleteUser(Long id);/**

    * 修改用户

    * @param user 用户信息

    */dvUserupdateUser(dvUser user);/**

    * 查询所有用户

    */List<dvUser>findAllUser();/**

    * 通过id查询用户

    * @param id 用户id

    */dvUserfindUserById(Long id);}

8、创建service接口实现类

importcom.jacky.userservice.pojo.entity.dvUser;importcom.jacky.userservice.repository.dvUserRepository;importcom.jacky.userservice.service.dvUserService;importorg.springframework.stereotype.Service;importjavax.annotation.Resource;importjava.util.List;@ServicepublicclassdvUserServiceImplimplementsdvUserService{@ResourceprivatedvUserRepository dvUserRepository;@OverridepublicdvUserinsertUser(dvUser user){returndvUserRepository.save(user);}@OverridepublicvoiddeleteUser(Long id){dvUserRepository.deleteById(id);}@OverridepublicdvUserupdateUser(dvUser user){returndvUserRepository.save(user);}@OverridepublicList<dvUser>findAllUser(){returndvUserRepository.findAll();}@OverridepublicdvUserfindUserById(Long id){returndvUserRepository.findById(id).orElse(null);}}

9、创建controller访问层

importcom.jacky.userservice.pojo.entity.dvUser;importcom.jacky.userservice.service.dvUserService;importorg.springframework.web.bind.annotation.*;importjavax.annotation.Resource;importjava.util.List;@RestController@RequestMapping("/user")publicclassJpaUserController{@ResourceprivatedvUserService dvUserService;/**

    * 新增用户

    */@PostMapping("")publicdvUseraddUser(@RequestBody dvUser user){returndvUserService.insertUser(user);}/**

    * 删除用户

    */@DeleteMapping("/{id}")publicvoiddeleteUser(@PathVariable("id")Long id){dvUserService.deleteUser(id);}/**

    * 修改用户

    */@PutMapping("")publicdvUserupdateUser(@RequestBody dvUser user){returndvUserService.updateUser(user);}/**

    * 全查用户

    */@GetMapping("")publicList<dvUser>findAll(){returndvUserService.findAllUser();}/**

    * id查用户

    */@GetMapping("/{id}")publicdvUserfindbyId(@PathVariable("id")Long id){returndvUserService.findUserById(id);}}

四、是实时展示真正的技术了

1、费了老大的劲才把代码敲完,现在是开始见证成果的时候了,让我们使用Post模拟请求

先添加一个用户

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容