1. 导入依赖

首先新建一个springboot项目,勾选组件时勾选Spring Web、JDBC API、MySQL Driver

pom.xml配置文件导入依赖

<!--mybatis-spring-boot-starter-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.4</version>
</dependency>

2. 连接数据库

使用idea链接数据库

idea右上方选择database,新建一个数据源,我的是mysql,就创建的mysql的数据源

成功则会

查看user表

3. 编写数据库配置信息

在springboot配置文件application.properties中配置数据库信息

spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

4. 编写pojo实体类

在主程序同级目录下新建pojo包,其中新建User实体类(使用了lombok减少了代码量)

使用lombok需要pom.xml导入依赖

<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.20</version>
</dependency>

User实体类:

package cn.dzp.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor; @Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
private int id;
private String name;
private String pwd;
}

5. 编写mapper接口

在主程序同级目录下新建mapper包,其中新建UserMapper接口

package cn.dzp.mapper;

import cn.dzp.pojo.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository; import java.util.List; @Mapper//这个注解表示了这是一个mybatis的mapper类:Dao
@Repository
public interface UserMapper {
List<User> queryUserList(); User queryUserById(@Param("id") int id); int addUser(User user); int deleteUserById(int id); int updateUser(User user);
}

6. 编写mapper.xml

在resources目录下新建mabatis包,其中新建mapper包,再在其中新建mapper.xml

代码如下:

<?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="cn.dzp.mapper.UserMapper">
<select id="queryUserList" resultType="user">
select * from user
</select> <select id="queryUserById" resultType="user">
select * from user where id=#{id}
</select> <insert id="addUser" parameterType="user">
insert into user values (#{id},#{name},#{pwd})
</insert> <update id="updateUser" parameterType="user">
update user set name=#{name},pwd=#{pwd} where id = #{id}
</update> <delete id="deleteUserById">
delete * from user where id = #{id}
</delete>
</mapper>

然后需要到springboot核心配置文件application.properties中绑定mapper.xml文件

#整合mybatis
mybatis.type-aliases-package=cn.dzp.pojo
mybatis.mapper-locations=classpath:mybatis/mapper/*.xml

7. 编写controller

在主程序同级目录下新建controller包,在其中新建UserController

package cn.dzp.controller;

import cn.dzp.mapper.UserMapper;
import cn.dzp.pojo.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import java.util.List; @RestController
public class UserController {
@Autowired
private UserMapper userMapper; @RequestMapping("/queryUserList")
public List<User> queryUserList(){
List<User> users = userMapper.queryUserList();
for (User user : users) {
System.out.println(user);
}
return users;
} @GetMapping("/queryUserByID")
public User queryUserByID() {
User user = userMapper.queryUserById(2);
return user;
} @GetMapping("/addUser")
public String addUser() {
userMapper.addUser(new User(5, "Godas_Lsy", "89720"));
return "增加用户OK";
} @GetMapping("/updateUser")
public String updateUser() {
userMapper.updateUser(new User(5, "Godas_Lsy", "123456"));
return "修改用户OK";
} @GetMapping("/deleteUserById")
public String deleteUser() {
userMapper.deleteUserById(5);
return "删除用户OK";
}
}

8. 测试

启动springboot应用进行测试

访问



其他测试以此类推,此处不再进行测试

到此文章结束

最新文章

  1. Linux的tree命令
  2. 关于把.net 2.0的项目升级到.net4.0遇到的一些问题
  3. UWP开发入门(十六)——常见的内存泄漏的原因
  4. FZU 2093 找兔子 状压DP
  5. golang的推荐的orm库
  6. WinpCap 使用线程发数,明明发了,返回值0是OK的啊,怎么抓包看不到,难道不支持多线程。。。
  7. SB中使用Autolayout设置到父视图的间距为0
  8. 从0到1一步步搭建代码质量检测系统~iOS
  9. 区块链Fabric技术在托管业务中的运用初探
  10. 国内apk加固的破解方法
  11. 如何检测 Android Cursor 泄漏
  12. 软件工程(GZSD2015)第三次作业提交进度
  13. Anaconda安装及使用
  14. 如何用VSCode调试Vue.js
  15. 【165223&amp;165218】结对感想——论如何与队友完美配合
  16. 2019.02.11 bzoj4767: 两双手(组合数学+容斥dp)
  17. Mysql数据库多表查询
  18. iOS UI进阶-5.0 蓝牙/加速计/传感器
  19. STL-stack和顺序栈实现括号匹配
  20. How to tell if a file is an EXE or a DLL?

热门文章

  1. 浅入Kubernetes(8):外网访问集群
  2. spring data jpa之Auditing 表的创建时间,更新时间自动生成策略
  3. 3- MySQL数据类型
  4. POJ2186 强联通
  5. Building Fire Stations 39届亚洲赛牡丹江站B题
  6. WPScan工具的使用(WordPress扫描工具)
  7. 使用同步或异步的方式完成 I/O 访问和操作(Windows核心编程)
  8. React-状态提升
  9. 攻防世界Web刷题记录(新手区)
  10. 1、requests基础