前言

之前一段时间学习了一些springboot的一些基础使用方法和敲了一些例子,是时候写一个简单的crud来将之前学的东西做一个整合了 —— 一个员工列表的增删改查。

使用 restful api

这次的CRUD将使用restful api的风格,restful api的风格现在非常流行,那restful api和传统的api有什么区别呢?

举个例子来说吧

查找某个用户

  • 传统api: /getUserByID?id=123
  • restful api: 使用GET方法 /user/123

添加用户

  • 传统api:/addUser?xxx
  • restful api: 使用POST方法 /user

restful api 使用统一资源标识符(URI)来寻址资源。所带的参数直接用“/”跟在后面,“/”用来表示指示层级关系,而不会用?key=value的方式来定义URI。

另外,restful api中对http请求方法的使用也有讲究, GET:查询,POST:新增,PUT:更新,DELETE:删除。restful api用HTTP请求方式区分对资源CRUD操作

而在传统的api中一般简单的就用GET,复杂一点的就用POST,传统api使用crud来区分操作

下面我先定义一下这次实现restful crud 的请求架构

功能 请求URI 请求方式
查询所有员工 /emps GET
查询某个员工 /emp/{id} GET
来到添加页面 /emp GET
添加员工 /emp POST
修改员工 /emp PUT
删除员工 /emp/{id} DELETE

使用thymeleaf模板引擎

thymeleaf是springboot推荐使用的模板引擎,我用起来也是十分舒服的,再也不用像之前那样苦逼地在js中拼接字符串了。

同时,前端页面用的是基于bootstrap 的一套模板页面。

就先介绍这么多了,有其他要补充的就要下面的实践中说吧,下面,我们就开始一步步构建这个restful crud!!

开发环境:springboot2.1.6、maven3.3.6、jdk 8、IDEA 2018、mysql5.7


创建项目,引入依赖

  1. <!--web-->
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-thymeleaf</artifactId>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework.boot</groupId>
  8. <artifactId>spring-boot-starter-web</artifactId>
  9. </dependency>
  10. <!--数据库依赖-->
  11. <dependency>
  12. <groupId>org.mybatis.spring.boot</groupId>
  13. <artifactId>mybatis-spring-boot-starter</artifactId>
  14. <version>2.1.0</version>
  15. </dependency>
  16. <dependency>
  17. <groupId>mysql</groupId>
  18. <artifactId>mysql-connector-java</artifactId>
  19. <scope>runtime</scope>
  20. </dependency>
  21. <!--测试-->
  22. <dependency>
  23. <groupId>org.springframework.boot</groupId>
  24. <artifactId>spring-boot-starter-test</artifactId>
  25. <scope>test</scope>
  26. </dependency>

在application.yml中进行数据库配置

  1. spring:
  2. #数据库配置
  3. datasource:
  4. url: jdbc:mysql://localhost:3306/restFulCrud?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8
  5. username: root
  6. password: root
  7. driver-class-name: com.mysql.jdbc.Driver
  8. #mybatis配置
  9. mybatis:
  10. mapper-locations: classpath:mapper/*.xml
  11. type-aliases-package: com.jotal.springboot08restfulcrud.entities

mapper-location就是放置mybatis映射文件的地方,classpath: 表示包名下 src->main->resources/

type-aliases-package 为实体类添加别名,方便使用

实体类

Employee员工类

  1. package com.jotal.springboot08restfulcrud.entities;
  2. public class Employee {
  3. private Integer emp_id;
  4. private String lastName;
  5. private String email;
  6. //1 male, 0 female
  7. private Integer gender;
  8. private Department department;
  9. private Date birth;
  10. //getter、setter、constructor、toString
  11. }

Department部门类

  1. package com.jotal.springboot08restfulcrud.entities;
  2. public class Department {
  3. private Integer departmentId;
  4. private String departmentName;
  5. //getter、setter、constructor、toString

User系统用户类

  1. package com.jotal.springboot08restfulcrud.entities;
  2. public class User {
  3. private String username;
  4. private String password;
  5. //getter、setter、constructor、toString
  6. }

创建数据库,添加数据

  1. DROP TABLE IF EXISTS `department`;
  2. CREATE TABLE `department` (
  3. `departmentId` int(10) NOT NULL AUTO_INCREMENT,
  4. `departmentName` varchar(50) NOT NULL,
  5. PRIMARY KEY (`departmentId`)
  6. ) ENGINE=InnoDB AUTO_INCREMENT=104 DEFAULT CHARSET=utf8;
  7. INSERT INTO `department` VALUES ('101', 'A-A');
  8. INSERT INTO `department` VALUES ('102', 'B-B');
  9. INSERT INTO `department` VALUES ('103', 'C-C');
  10. DROP TABLE IF EXISTS `employee`;
  11. CREATE TABLE `employee` (
  12. `emp_id` int(10) NOT NULL AUTO_INCREMENT,
  13. `lastName` varchar(20) NOT NULL,
  14. `email` varchar(100) NOT NULL,
  15. `gender` tinyint(2) NOT NULL DEFAULT '1' COMMENT '0:女\r\n1:男',
  16. `birth` date NOT NULL,
  17. `department` int(10) DEFAULT NULL,
  18. PRIMARY KEY (`emp_id`),
  19. KEY `dept` (`department`),
  20. CONSTRAINT `dept` FOREIGN KEY (`department`) REFERENCES `department` (`departmentId`) ON DELETE SET NULL ON UPDATE CASCADE
  21. ) ENGINE=InnoDB AUTO_INCREMENT=1008 DEFAULT CHARSET=utf8;
  22. INSERT INTO `employee` VALUES ('1001', 'AA01', '1001@j.com', '1', '2019-08-12', '101');
  23. INSERT INTO `employee` VALUES ('1002', 'BB02', '1002@j.com', '1', '2019-08-17', '102');
  24. INSERT INTO `employee` VALUES ('1003', 'CC03', '1003@j.com', '1', '2019-08-05', '103');
  25. INSERT INTO `employee` VALUES ('1004', 'CC04', '1004@j.com', '0', '2019-08-12', '103');
  26. INSERT INTO `employee` VALUES ('1005', 'jotal', '1066@qq.com', '1', '1997-10-07', '102');
  27. DROP TABLE IF EXISTS `user`;
  28. CREATE TABLE `user` (
  29. `username` varchar(50) NOT NULL,
  30. `password` varchar(50) NOT NULL
  31. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  32. INSERT INTO `user` VALUES ('admin', '123');
  33. INSERT INTO `user` VALUES ('jotal', '123');

其中创建数据库的时候我遇到了一个错误,特此记录一下。

employee表中的department存的是departmentId 部门ID,department设为外键,我设置如果父表department删除了该部门,employee中的department字段就设置为空,但是之前设计的时候employee的department字段我设置了not null,所以保存的时候会出错。解决办法就是department字段设置可以为空就可以了。

看一下外键约束的四种方式:

CASCADE:父表delete、update的时候,子表会delete、update掉关联记录;

SET NULL:父表delete、update的时候,子表会将关联记录的外键字段所在列设为null,所以注意在设计子表时外键不能设为not null;

RESTRICT:如果想要删除父表的记录时,而在子表中有关联该父表的记录,则不允许删除父表中的记录 ; NO ACTION:同 RESTRICT,也是首先先检查外键;

今天我们先讲到这里,今天主要就是介绍了一下这个crud的一些要点,例如使用什么技术,是什么风格的。还有创建了项目,添加了数据,紧接着要做的就是写dao层,看能不能成功从数据库中取出数据。see you!

使用springboot实现一个简单的restful crud——01、项目简介以及创建项目的更多相关文章

  1. 使用springboot实现一个简单的restful crud——03、前端页面、管理员登陆(注销)功能

    前言 这一篇我们就先引入前端页面和相关的静态资源,再做一下管理员的登陆和注销的功能,为后续在页面上操作数据做一个基础. 前端页面 前端的页面是我从网上找的一个基于Bootstrap 的dashboar ...

  2. 使用springboot实现一个简单的restful crud——02、dao层单元测试,测试从数据库取数据

    接着上一篇,上一篇我们创建了项目.创建了实体类,以及创建了数据库数据.这一篇就写一下Dao层,以及对Dao层进行单元测试,看下能否成功操作数据库数据. Dao EmpDao package com.j ...

  3. 使用webpy创建一个简单的restful风格的webservice应用

    下载:wget http://webpy.org/static/web.py-0.38.tar.gz解压并进入web.py-0.38文件夹安装:easy_install web.py 这是一个如何使用 ...

  4. 使用springboot写一个简单的测试用例

    使用springboot写一个简单的测试用例 目录结构 pom <?xml version="1.0" encoding="UTF-8"?> < ...

  5. springboot搭建一个简单的websocket的实时推送应用

    说一下实用springboot搭建一个简单的websocket 的实时推送应用 websocket是什么 WebSocket是一种在单个TCP连接上进行全双工通信的协议 我们以前用的http协议只能单 ...

  6. 【SpingBoot】 测试如何使用SpringBoot搭建一个简单后台1

    很久没写博客了,最近接到一个组内的测试开发任务是做一个使用SpringBoot 开发一个后台程序(还未完成),特写感想记录一下 1. 为什么选择SpringBoot ? 首先是目前很多公司的后台还是J ...

  7. 基础项目构建,引入web模块,完成一个简单的RESTful API 转载来自翟永超

    简介 在您第一次接触和学习Spring框架的时候,是否因为其繁杂的配置而退却了?在你第n次使用Spring框架的时候,是否觉得一堆反复粘贴的配置有一些厌烦?那么您就不妨来试试使用Spring Boot ...

  8. laravel 实现一个简单的 RESTful API

    创建一个 Article 资源 php artisan make:resource Article 你可以在 app/Http/Resources 目录下看到你刚刚生成的 Article 资源 当然我 ...

  9. 一、基础项目构建,引入web模块,完成一个简单的RESTful API

    一.Spring Boot的主要优点: 为所有Spring开发者更快的入门 开箱即用,提供各种默认配置来简化项目配置 内嵌式容器简化Web项目 没有冗余代码生成和XML配置的要求 二.使用maven构 ...

随机推荐

  1. element ui,input框输入时enter健进行搜索

    <el-form-item label="企业名称"> <el-input v-model="formSearch.kw" @keyup.en ...

  2. D3.js的v5版本入门教程(第五章)—— 选择、插入、删除元素

    D3.js的v5版本入门教程(第五章) 1.选择元素 现在我们已经知道,d3.js中选择元素的函数有select()和selectAll(),下面来详细讲解一下 假设我们的<body>中有 ...

  3. 拉格朗日插值法(c++)

    已给sin0.32=0.314567,sin0.34=0.333487,sin0.36=0.352274,计算sin0.3367的值 #include <iostream> #includ ...

  4. pgsql 聚合函数array_to_string,ARRAY_AGG

    array_to_string--将sql中的数组转为字符串 ARRAY_AGG--将sql中的数据转为数组处理 以下给大家一个简单的例子即可体会: 1.需求     2.数据库中原数据   1.pn ...

  5. EFProf用法

    SQL Server Profiler用来跟踪应用程序发送到SQL Server中的SQL语句,用于检测性能,查找问题.Entity Framework 也有它的跟踪工具EFProf,用于跟踪Enti ...

  6. Spring cloud微服务安全实战-7-9自定义日志采集的格式和内容

    怎么来控制输出的日志的格式.并且从日志里面提取出来我想要的一些信息. 整个的message是一个大的json格式字符串. 虽然是可以通过关键字搜索到.但是日志看起来并不舒服. 在我们的控制台,日志实际 ...

  7. 浏览器低延时播放监控摄像头RTSP海康大华硬盘录像机NVR视频(EasyNVR播放FLV视频流)

    背景描述 EasyNVR的使用者应该都是清楚的知道,EasyNVR一个强大的功能就是可以进行全平台的无插件直播.主要原因在于rtsp协议的视频流(默认是需要插件才可以播放的)经由EasyNVR处理后可 ...

  8. UE4 ios环境搭建备忘

    1.windows.mac安装证书 2.安装xcode .app -- 路径可以拖入 sudo gem install xcodeproj 3.错误处理 Setting up Mono Running ...

  9. Android MVP框架实现登录案例

    一.Model package com.czhappy.mvpdemo.model; /** * author: chenzheng * created on: 2019/5/16 11:06 * d ...

  10. Python界面常用GUI包

    作为Pyhon开发者,你迟早都会碰到图形用户界面(GUI)应用开发任务,这时候我们就需要一些界面库来帮助我们快速搭建界面,python的界面库很多,我认识的并不多,这里只列出几种我认识的 1.tkin ...