写点什么

前端向后端进发之 ----Springboot JPA 增删改查,外包 Java 后端开发三年

用户头像
极客good
关注
发布于: 刚刚

这里不截图相关的代码了,不太好弄,只是介绍一些要用到的概念,要结合 demo 来看,是前后分离的,前端用 vue,[demo 地址点这里](


),demo 里有些是使用原生 sql,主要是为了学习,其实 springboot jpa 都能实现,另外 jpa 还是有很多东西要学的,这里都只是入门而已。


在了解了 jpa 的概念之后,突然觉得一个好的框架真的能省下来不少麻烦事,这也是一个框架存在的意义,回想起以前用.net 维护老系统的时候,全是手写 sql 语句,动不动就是三百行 sql,简直要哭了。


这个过程中可以会让人钻进死胡同的地方有:一是后端是怎么接到请求的,二是什么是注解。这两点让后困惑了很久,不知道是不是其他前端人的困惑。对于一,千万不要钻到计算机网络方面的胡同里,怎么接收到请求不用去考虑,当一个后端服务起来之后,是 Tomcat 等这些服务接管了代码,怎么接收的是 Tomcat 服务的事,反正路径,端口对了之后,剩下的就是 Tomcat 的事,还没有水平去操心这方面的东西。对于二,注解就是 java 的东西,我也没去深究,就简单的可以理解为一个语法糖吧,不必关系它是怎么实现的,目前只管知道怎么使用就够了,就像 vue 中 v-if,v-for 一样,不必去关系它怎么就能实现那个效果,这是框架带来的,不是我们所考虑的东西。


[](


)开始


==============================================================


springboot 内置了一些基本的 CRUD 方法,目的就是减少开发人员亲自去写 sql 语句,在了解 springboot jpa 的相关东西之前,有一个前置的知识就是 spring mvc,其实也就是 mvc 模式,这个东西网上有很多资料,这里就不去介绍了。spring mvc 中有一些概念controllerservicedao,这三个是很重要概念,至于它们的概念和作用,同样网上很多资料。


简单的说就是:controller是负责与前端对接并转发处理请求,最后把最终的处理结果返回给前端;service负责进行业务的处理;dao负责操作数据库;这三个各司其职能使项目结构清晰便于理解,同时降低代码的耦合。


一个完整的过程为:当一个前端请求过来后,首先进入的是controller,`con


【一线大厂Java面试题解析+核心总结学习笔记+最新架构讲解视频+实战项目源码讲义】
浏览器打开:qq.cn.hn/FTf 免费领取
复制代码


troller接收到之后,根据请求的路径进行匹配,匹配到之后执行关联的方法,而这个方法中则会调用service的方法,service的执行业务逻辑的操作,如果涉及到数据库的操作,则会调用dao中的方法,这里的方法中就是对数据的操作了。重点来了:1、dao中只要继承springboot的JpaRepository接口,就能对数据库进行增删改查,无须自己写sql。2、dao也可以通过@Query`注解自己去写 sql 实现对数据库的增删改查。


[](


)关于 JPA


=================================================================


https://my.oschina.net/u/3080373/blog/1828589


jpa 是一种规范,它通过注解或者 XML 描述【对象-关系表】之间的映射关系,并将实体对象持久化到数据库中


目的是让开发者从繁琐的 JDBC 和 SQL 代码中解脱出来。


JPA 仅仅定义了一些接口,而接口是需要实现才能工作的。所以底层需要某种实现,而 Hibernate 就是实现了 JPA 接口的 ORM 框架


https://segmentfault.com/a/1190000021755149


我们原来使用 JDBC 连接来读写数据库,我们最常见的就是打开数据库连接、使用复杂的 SQL 语句进行读写、关闭连接,


获得的数据又需要转换或封装后往外传,这是一个非常烦琐的过程。这时出现了 Hibernate 框架,它需要你创建一系列的持久化类,


每个类的属性都可以简单的看做和一张数据库表的属性一一对应。这样我们不用在关注数据库,只需要持久化类就可以完成增删改查的功能。


使我们的软件开发真正面向对象, 而不是面向混乱的代码。


实体对象≠持久化对象。因为实体对象涵盖更广泛,它可以是持久化对象,也可以是内存中的任何对象。


[](


)关于实体 Entity


======================================================================


简单的理解 entity,就是一个实体类,一般对应数据库中一张表,那为什么要有这个东西?那么就反过来想,为什么继承了JpaRepository接口就不用写 sql 了,没有这个 bean[(什么是 bean 上)](


)[(什么是 bean 下)](


)告诉 springboot 在数据库有这么一张表,表里有这些字段,springboot 怎么能对数据库的表进行增删改查呢。


[](


)关于 @RequestMapping()


===============================================================================


@RequestMapping()就是用来解析 url 并映射到 controller 中的方法,如下


/**


  • 模糊查询并分页

  • @param userName

  • @return


*/


@RequestMapping(value = "/getUserByNamePage",params = {"userName","currentPage","pageSize"})


public List getUserByNamePage(@RequestParam String userName,int currentPage,int pageSize){


return userService.getUserByNamePage(userName,currentPage,pageSize);


}


当后端接收到请求http://localhost:8081/getUserByNamePage?userName=张三&currentPage=1&pageSize=10之后,会解析这个 url 获得getUserByNamePage这一段,那么就匹配上了@RequestMapping("/getUserByNamePage"),然后开始执行getUserByNamePage()这个方法。


@RequestParam是获取路径上的请求参数,注意和@PathVariable()不同,这个是获取 path 参数,比如这种/getXXX/{id}


@RequestBody是获取 body 里的参数

用户头像

极客good

关注

还未添加个人签名 2021.03.18 加入

还未添加个人简介

评论

发布
暂无评论
前端向后端进发之----Springboot JPA增删改查,外包Java后端开发三年