前端向后端进发之 ----Springboot JPA 增删改查,外包 Java 后端开发三年
这里不截图相关的代码了,不太好弄,只是介绍一些要用到的概念,要结合 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 中有一些概念controller
,service
,dao
,这三个是很重要概念,至于它们的概念和作用,同样网上很多资料。
简单的说就是:controller
是负责与前端对接并转发处理请求,最后把最终的处理结果返回给前端;service
负责进行业务的处理;dao
负责操作数据库;这三个各司其职能使项目结构清晰便于理解,同时降低代码的耦合。
一个完整的过程为:当一个前端请求过来后,首先进入的是controller
,`con
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=张三¤tPage=1&pageSize=10
之后,会解析这个 url 获得getUserByNamePage
这一段,那么就匹配上了@RequestMapping("/getUserByNamePage")
,然后开始执行getUserByNamePage()
这个方法。
@RequestParam
是获取路径上的请求参数,注意和@PathVariable()
不同,这个是获取 path 参数,比如这种/getXXX/{id}
@RequestBody
是获取 body 里的参数
评论