热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【SpringBoot】111.Springboot整合Springmvc+Mybatis增删改查操作(下)

整合过程:https:www.isdxh.com68.html一、增——增加用户1.创建实体类packagecom.dxh.pojo;publicclassUsers{privat

整合过程:https://www.isdxh.com/68.html

一、增——增加用户

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);
}




	
	
		insert into users(name,age) values (#{name},#{age})
	

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








	
		userName: 
userAge:







	 addUser Success!


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 selectUserAll();

2.在业务层中添加查询方法

List findUserAll();
	@Override
	public List findUserAll() {
		return this.usersMapper.selectUserAll();
	}

3.编写controller

/**
	 * 查询全部用户
	 */
	@RequestMapping("/findUserAll")
	public String findUserAll(Model model) {
		List list =  this.usersService.findUserAll();
		model.addAttribute("list",list);
		return "showUsers";
	}

4.创建页面

在src/main/resources/templates/showUsers.html








	
ID 名称 年龄

5.访问

http://localhost:8080/users/findUserAll

三、改——用户更新

分为两部分,一是数据回显,二是提交页面

1.修改Mapper文件和映射配置

Users selectUsersById(Integer id);

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页面








	
	
		userName: 
userAge:

5.编辑showUsers.html文件








	
ID 名称 年龄 操作
更新用户

6.修改Mapper接口和映射配置文件

void updateUser(Users users);
	
		update users set name=#{name} , age=#{age} where id=#{id}
	

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 from users where id = #{id}
	

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








	
ID 名称 年龄 操作
更新用户
删除用户

5.完成!


推荐阅读
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
author-avatar
工程技术公司团委
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有