【SpringBoot】11-1.Springboot整合Springmvc+Mybatis增删改查操作(下)
一、增——增加用户
1.创建实体类
package com.dxh.pojo;
public class Users {
	private Integer id;
	private String name;
	private Integer age;
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Integer getAge() {
		return age;
	}
	public void setAge(Integer age) {
		this.age = age;
	}
}
2.创建mapper接口以及映射配置文件
package com.dxh.mapper;
import com.dxh.pojo.Users;
public interface UsersMapper {
	void insertUser(Users users);
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.dxh.mapper.UsersMapper">
	<!-- 在properties文件中配置过别名了,所以parameterType不需要写Users的包的名称了 -->
	<insert id="insertUser" parameterType="Users">
		insert into users(name,age) values (#{name},#{age})
	</insert>
</mapper>
3.创建业务层
package com.dxh.service.impl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.dxh.mapper.UsersMapper;
import com.dxh.pojo.Users;
import com.dxh.service.UsersService;
@Service
@Transactional
public class UserServiceImpl implements UsersService{
	@Autowired
	private UsersMapper usersMapper;
	@Override
	public void addUser(Users users) {
		this.usersMapper.insertUser(users);
	}
}
package com.dxh.service;
import com.dxh.pojo.Users;
public interface UsersService {
	void addUser(Users users);
}
4.创建Controller
package com.dxh.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import com.dxh.pojo.Users;
import com.dxh.service.UsersService;
@Controller
@RequestMapping("/users")
public class UsersController {
	@Autowired
	private UsersService usersService;
	/**
	 * 页面跳转的方法
	 */
	@RequestMapping("/{page}")
	public String showPage(@PathVariable String page) {
		return page;
	}
	/**
	 * 添加用户
	 */
	@RequestMapping("/addUser")
	public String addUser(Users users) {
		this.usersService.addUser(users);
		return "ok";
	}
}
5.编写页面:src/main/resources/templates/ input.html 和 ok.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>AddUser</title>
</head>
<body>
	<form th:action="@{/users/addUser}" method="post">
		userName: <input type="text" name="name"/></br>
		userAge: <input type="text" name="age"/></br>
		<input type="submit" value="SUBMIT">
	</form>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>OK</title>
</head>
<body>
	 addUser Success!
</body>
</html>
6.启动类:
- 新增注解:@MapperScan("com.dxh.mapper") //用于扫描mybatis的Mapper接口
package com.dxh;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("com.dxh.mapper")	//用于扫描mybatis的Mapper接口
public class App {
	public static void main(String[] args) {
		SpringApplication.run(App.class, args);
	}
}
二、查——查询用户
1.在mapper接口中以及映射配置文件中添加相关代码
List<Users> selectUserAll();
<select id="selectUserAll" resultType="Users">
	SELECT id,name,age from users
</select>
2.在业务层中添加查询方法
List<Users> findUserAll();
	@Override
	public List<Users> findUserAll() {
		return this.usersMapper.selectUserAll();
	}
3.编写controller
/**
	 * 查询全部用户
	 */
	@RequestMapping("/findUserAll")
	public String findUserAll(Model model) {
		List<Users> list =  this.usersService.findUserAll();
		model.addAttribute("list",list);
		return "showUsers";
	}
4.创建页面
在src/main/resources/templates/showUsers.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>展示用户数据</title>
</head>
<body>
	<table border="1" style="width:300px">
		<tr>
			<th>ID</th>
			<th>名称</th>
			<th>年龄</th>
		</tr>
		<tr th:each="user : ${list}">
			<td th:text="${user.id}"></td>
			<td th:text="${user.name}"></td>
			<td th:text="${user.age}"></td>
		</tr>
	</table>
</body>
</html>
5.访问
http://localhost:8080/users/findUserAll
三、改——用户更新
分为两部分,一是数据回显,二是提交页面
1.修改Mapper文件和映射配置
Users selectUsersById(Integer id);
<select id="selectUsersById" resultType="Users" parameterType="int">
		SELECT id,name,age from users where id = #{id}
</select>
2.修改业务层代码
Users findUserById(Integer id);
	@Override
	public Users findUserById(Integer id) {
		return this.usersMapper.selectUsersById(id);
	}
3.编写Controller
	/**
	 * 根据用户id查询用户
	 */
	@RequestMapping("/findUserById")
	public String findUserById(Integer id ,Model model) {
		Users user = this.usersService.findUserById(id);
		model.addAttribute("user",user);
		return "updatePage";
	}
4.在src/main/resources/templates/updatePage.html创建html页面
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<form th:action="@{/users/editUser}" method="post">
	<input type="hidden" name="id" th:field="${user.id}">
		userName: <input type="text" name="name" th:field="${user.name}"/></br>
		userAge: <input type="text" name="age" th:field="${user.age}"/></br>
		<input type="submit" value="SUBMIT">
	</form>
</body>
</html>
5.编辑showUsers.html文件
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>展示用户数据</title>
</head>
<body>
	<table border="1" style="width:300px">
		<tr>
			<th>ID</th>
			<th>名称</th>
			<th>年龄</th>
			<th>操作</th>
		</tr>
		<tr th:each="user : ${list}">
			<td th:text="${user.id}"></td>
			<td th:text="${user.name}"></td>
			<td th:text="${user.age}"></td>
			<td>
				<a th:href="@{/users/findUserById(id=${user.id})}">更新用户</a>
			</td>
		</tr>
	</table>
</body>
</html>
6.修改Mapper接口和映射配置文件
void updateUser(Users users);
	<update id="updateUser" parameterType="Users">
		update users set name=#{name} , age=#{age} where id=#{id}
	</update>
7.修改业务层代码
void updateUser(Users users);
	@Override
	public void updateUser(Users users) {
		this.usersMapper.updateUser(users);
	}
8.编写controller
	@RequestMapping("/editUser")
	public String editUser(Users users,Model model) {
		this.usersService.updateUser(users);
		return "ok";
	}
四、删——删除用户
1.修改Mapper以及映射配置文件
void deleteUserByid(Integer id);
	<delete id="deleteUserByid">
		delete from users where id = #{id}
	</delete>
2.修改业务层方法
void deleteUserById(Integer id);
	@Override
	public void deleteUserById(Integer id) {
		this.usersMapper.deleteUserByid(id);
	}
3.修改controller
	/**
	 * 删除用户
	 */
	@RequestMapping("/delUser")
	public String delUser(Integer id) {
		this.usersService.deleteUserById(id);
		return "redirect:/users/findUserAll";
	}
4.修改showUsers.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>展示用户数据</title>
</head>
<body>
	<table border="1" style="width:300px">
		<tr>
			<th>ID</th>
			<th>名称</th>
			<th>年龄</th>
			<th>操作</th>
		</tr>
		<tr th:each="user : ${list}">
			<td th:text="${user.id}"></td>
			<td th:text="${user.name}"></td>
			<td th:text="${user.age}"></td>
			<td>
				<a th:href="@{/users/findUserById(id=${user.id})}">更新用户</a></br>
				<a th:href="@{/users/delUser(id=${user.id})}">删除用户</a>
			</td>
		</tr>
	</table>
</body>
</html>
5.完成!
【SpringBoot】11-1.Springboot整合Springmvc+Mybatis增删改查操作(下)的更多相关文章
- springmvc+spring3+hibernate4框架简单整合,简单实现增删改查功能
		转自:https://blog.csdn.net/thinkingcao/article/details/52472252 C 所用到的jar包 数据库表 数据库表就不用教大家了,一张表,很简 ... 
- 用SpringBoot+MySql+JPA实现对数据库的增删改查和分页
		使用SpringBoot+Mysql+JPA实现对数据库的增删改查和分页 JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述 ... 
- MyBatis增删改查
		MyBatis的简介: MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名 ... 
- MyBatis增删改查模板
		1. 首先,和Spring整合一下 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=& ... 
- springMVC实现增删改查
		首先需要准备好一张数据库表我这里用emp这张表:具体代码: /* SQLyog 企业版 - MySQL GUI v8.14 MySQL - 5.1.73-community ************* ... 
- MyBatis批量增删改查操作
		前文我们介绍了MyBatis基本的增删该查操作,本文介绍批量的增删改查操作.前文地址:http://blog.csdn.net/mahoking/article/details/43673741 ... 
- 【Mybatis】简单的mybatis增删改查模板
		简单的mybatis增删改查模板: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE map ... 
- MyBatis学习之简单增删改查操作、MyBatis存储过程、MyBatis分页、MyBatis一对一、MyBatis一对多
		一.用到的实体类如下: Student.java package com.company.entity; import java.io.Serializable; import java.util.D ... 
- 最简单的mybatis增删改查样例
		最简单的mybatis增删改查样例 Book.java package com.bookstore.app; import java.io.Serializable; public class Boo ... 
随机推荐
- CentOS openssh升级到openssh-7.2版本
			查看现在的版本SSH -V 一.准备 备份ssh目录(重要) cp -rf /etc/ssh /etc/ssh.bak [ 可以现场处理的,不用设置 安装telnet,避免ssh升级出现问题,导致无法 ... 
- 极简 Node.js 入门 - 4.5 双工流
			极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ... 
- 52.Qt-Charts动态显示多条折线电压值(实现示波器效果)
			Qt 5.7过后Qt添加了官方的Chart库,之前就用的比较习惯,这次把源码发出来,给入门的同学们参考参考. 效果如下所示: 1.chartsView.h如下所示: #ifndef VIEW_H #d ... 
- 多路复用select和epoll的区别(转)
			先说下本文框架,先是问题引出,然后概括两个机制的区别和联系,最后介绍每个接口的用法 一.问题引出 联系区别 问题的引出,当需要读两个以上的I/O的时候,如果使用阻塞式的I/O,那么可能长时间的阻塞在一 ... 
- nullptr解决了什么问题
			从0到NULL 在C++的世界中字面值0用来表示空指针,所以0可以当作所有指针类型的字面值.为了让语义更明确引入了NULL宏定义: #undef NULL #ifdef __cplusplus #de ... 
- 修改apt,pip,npm为国内镜像源
			apt 原文件备份 sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak 编辑源列表文件 sudo vim /etc/apt/sources. ... 
- 前端基础——HTML(二)
			HTML标签 标题标签<h1>.<h2>.<h3>.<h4>,标题标签之间是不能嵌套的,下一级标题与上级标题之间通过同级 关于书写,下级标题解释说明的是 ... 
- 八皇后C++版本
			emmmm~刚刚学C++,写一个八皇后,凑合看吧嘤嘤嘤 1 #include <iostream> 2 #include<cstdlib> 3 #include<cmat ... 
- 女朋友看了我的博客,说太LOW了,于是我搞了一天~
			持续原创输出,点击上方蓝字关注我 原创博客+1,点击左下角阅读原文进入 目录 前言 如何下载? 配置文件的分类 基本信息配置 修改主题 Next主题样式设置 添加动态背景 修改链接的样式 添加文章搜索 ... 
- vue 路由工程化重构
			当项目越来越庞大的时候,路由越来越多,而且遍布的页面也越来越多, 当需要更换地址的时候就无比的繁琐,通过学习了解到可以通过router.js来统一调控 原理: 在路由页面通过name来进行跳转,传入的 ... 
