Spring boot MyBatis基本操作
XML 配置方式
目录结构

数据库信息:
数据库student -> 表名 custom_user -> 主键-> custom_id ,其他字段 cusotm_name,custom_age
1.加入依赖
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.1</version>
</dependency>
pom.xml如下
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.guoxw</groupId>
<artifactId>mybatis_test</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>mybatis_test</name>
<description>Demo project for Spring Boot</description> <properties>
<java.version>1.8</java.version>
</properties> <dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency> <dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency> <dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.1</version>
</dependency> </dependencies> <build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build> </project>
2.mybatis-config.xml (暂时没有配置具体信息)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration> </configuration>
3. mapper/custom_user.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="com.guoxw.mybatis_test.mapper.CustomUserMapper"> <select id="findById" parameterType="Integer" resultType="com.guoxw.mybatis_test.entity.CustomUser">
select * from custom_user where custom_id =#{ value }
</select> <!-- 如果这里没有传入参数,不需要定义parameter ,如果是查询涉及多表,返回类型可以直接使用map 键值对-->
<!-- 使用LinkedHashMap 可以将map中的数据按照插入顺序进行排序 -->
<!-- #{custom_id} 传入参数,custom_id 是和map的key值对应-->
<!-- 可以加入if 语句 -->
<select id="findAll" parameterType="java.util.Map" resultType="java.util.Map"> select * from custom_user where custom_id > #{custom_id}
<if test="custom_age !=null">
and custom_age > #{custom_age}
</if>
<!-- select * from custom_user1 p ,custom_user2 d where p.nage=d.name --> </select> <insert id="create" parameterType="com.guoxw.mybatis_test.entity.CustomUser"> insert into custom_user ( custom_name,custom_age)
values (#{custom_name},#{custom_age})
<!-- selectKEY 用于回填数据 keyProperty 主键 keycolume是字段名 resultType 是字段类型 order 是指定在执行sql前或后返回数据-->
<selectKey keyProperty="custom_id" keyColumn="custom_id" resultType="Integer" order="AFTER">
select Last_INSERT_ID()
</selectKey> </insert> <update id="update" parameterType="com.guoxw.mybatis_test.entity.CustomUser"> update custom_user set custom_age = #{custom_age} where custom_id=2 </update> <delete id="del" parameterType="Integer">
delete from custom_user where custom_id=#{custom_id}
</delete>
</mapper>
4.CustomUserMapper
public interface CustomUserMapper {
public CustomUser findById(Integer id);
public List<Map> findAll(Map params);
public void create(CustomUser user);
public void update(CustomUser user);
public void del(Integer custom_id);
}
5.CustomUserService
@Service
public class CustomUserService { @Resource
private CustomUserMapper customUserMapper; public CustomUser findById(Integer id){ return customUserMapper.findById(id); } /***
*
* @return
*/
public List<Map> findAll(Integer id,Integer age){
Map params=new HashMap();
params.put("custom_id",id);
params.put("custom_age",age);
return customUserMapper.findAll(params);
} @Transactional
public void create(CustomUser user){ customUserMapper.create(user); } @Transactional
public void update(CustomUser user){ customUserMapper.update(user); } @Transactional
public void del(Integer custom_id){ customUserMapper.del(custom_id); } }
6. entity/CustomUser
public class CustomUser {
private Integer custom_id;
private String custom_name;
private Integer custom_age;
public Integer getCustom_id() {
return custom_id;
}
public void setCustom_id(Integer custom_id) {
this.custom_id = custom_id;
}
public String getCustom_name() {
return custom_name;
}
public void setCustom_name(String custom_name) {
this.custom_name = custom_name;
}
public Integer getCustom_age() {
return custom_age;
}
public void setCustom_age(Integer custom_age) {
this.custom_age = custom_age;
}
}
7. CustomUserController
@RestController
@RequestMapping(path = "/get")
public class CustomUserController { @Resource
CustomUserService customUserService; @RequestMapping(path = "/user/{id}")
public CustomUser findById(@PathVariable("id") int id){
return customUserService.findById(id); } @RequestMapping(path = "/user/all",method = RequestMethod.GET)
public List<Map>findAll(@RequestParam("custom_id") Integer custom_id, Integer custom_age){ List<Map> list=customUserService.findAll(custom_id,custom_age); return list;
} @RequestMapping(path = "/user/insert",method = RequestMethod.GET)
public CustomUser create(){
CustomUser user=new CustomUser();
user.setCustom_age(31);
user.setCustom_name("guoxw_4");
customUserService.create(user);
return user; } @RequestMapping(path = "/user/update",method = RequestMethod.GET)
public CustomUser update(){
CustomUser user=customUserService.findById(2);
user.setCustom_age(user.getCustom_age()*2);
customUserService.update(user);
return user; } @RequestMapping(path = "/user/del",method = RequestMethod.GET)
public String del(Integer id){
customUserService.del(id);
return "ok"; } }
8.yml
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf-8
username: root
password: 12345678
# jackson:
# deserialization: true
mybatis:
config-location: classpath:/mybatis/mybatis-config.xml
mapper-locations: classpath:/mybatis/mapper/*.xml
logging:
level:
com.guoxw.mybatis_test: debug
9. code :mybatis_test
链接:https://pan.baidu.com/s/1NTf_H-n2Ch0Wwe878I84ig 密码:49ak
注解方式
: 不再需要配置mybatis下的mapper.xml 和mybatis.config.xml 文件
yml配置文件
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: 123456
url: jdbc:mysql://localhost:3306/test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
mybatis:
configuration:
map-underscore-to-camel-case: true
logging:
level:
com.gail.mybatis2: debug
root: info
Mapper
@Mapper
public interface UserMapper { @Insert("insert into user(username,password) values(#{username},#{password})")
int addUser(@Param("username") String name, @Param("password") String password); // @Result 里面的property对应的是返回值User对象里面的字段, column 是指对应的数据库字段 @Results({
@Result(property = "id",column = "id"),
@Result(property = "name" ,column = "username"),
@Result(property = "pwd" ,column = "password")
})
@Select("select * from user where id =#{id}")
User findById(@Param("id") String id); @Update("update user set username=#{name} where id=#{id}")
void updateById(@Param("id") String id, @Param("username") String username); @Delete("delete from user where id=#{id}")
void deleteById(@Param("id") String id); @Results({
@Result(property = "id",column = "id"),
@Result(property = "name" ,column = "username"),
@Result(property = "pwd" ,column = "password")
})
@Select("select * from user")
List<User> findAllUser(); }
Service
@Service
public class UserService { @Resource
protected UserMapper userMapper; public User findById(String id) {
return userMapper.findById(id);
} public void addUser(String username, String pwd) {
userMapper.addUser(username, pwd);
} public void updataById(String id, String username) {
userMapper.updateById(id,username);
} public void deleteById(String id) {
userMapper.deleteById(id); } public List<User> findAllUser() {
return userMapper.findAllUser();
} }
entity
public class User {
private Integer id;
private String name;
private String pwd;
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 String getPwd() {
return pwd;
}
public void setPwd(String pwd) {
this.pwd = pwd;
}
}
Controller测试
@RestController
public class MyController { @Autowired
private UserService service; @RequestMapping(path = "/user/{id}")
public User finById(@PathVariable("id") String id){
return service.findById(id);
} @RequestMapping(path = "/user/add", method = RequestMethod.POST)
public void addUser(@RequestParam("name") String name, @RequestParam("pwd") String pwd){
service.addUser(name,pwd);
} @RequestMapping(path = "/get/all", method = RequestMethod.GET)
public List<User>findAllUser(){
return service.findAllUser();
}
}
Spring boot MyBatis基本操作的更多相关文章
- spring boot + mybatis + druid
因为在用到spring boot + mybatis的项目时候,经常发生访问接口卡,服务器项目用了几天就很卡的甚至不能访问的情况,而我们的项目和数据库都是好了,考虑到可能时数据库连接的问题,所以我打算 ...
- Spring Boot入门教程2-1、使用Spring Boot+MyBatis访问数据库(CURD)注解版
一.前言 什么是MyBatis?MyBatis是目前Java平台最为流行的ORM框架https://baike.baidu.com/item/MyBatis/2824918 本篇开发环境1.操作系统: ...
- spring boot + mybatis + druid配置实践
最近开始搭建spring boot工程,将自身实践分享出来,本文将讲述spring boot + mybatis + druid的配置方案. pom.xml需要引入mybatis 启动依赖: < ...
- spring boot+mybatis+quartz项目的搭建完整版
1. 利用spring boot提供的工具(http://start.spring.io/)自动生成一个标准的spring boot项目架构 2. 因为这里我们是搭建spring boot+mybat ...
- 快速搭建一个Spring Boot + MyBatis的开发框架
前言:Spring Boot的自动化配置确实非常强大,为了方便大家把项目迁移到Spring Boot,特意总结了一下如何快速搭建一个Spring Boot + MyBatis的简易文档,下面是简单的步 ...
- spring boot mybatis 打成可执行jar包后启动UnsatisfiedDependencyException异常
我的spring boot + mybatis项目在idea里面执行正常,但发布测试环境打成可执行jar包后就启动失败,提示错误如下: [ ERROR] [2018-08-30 17:23:48] o ...
- Spring Boot + Mybatis + Redis二级缓存开发指南
Spring Boot + Mybatis + Redis二级缓存开发指南 背景 Spring-Boot因其提供了各种开箱即用的插件,使得它成为了当今最为主流的Java Web开发框架之一.Mybat ...
- Spring Boot + Mybatis 实现动态数据源
动态数据源 在很多具体应用场景的时候,我们需要用到动态数据源的情况,比如多租户的场景,系统登录时需要根据用户信息切换到用户对应的数据库.又比如业务A要访问A数据库,业务B要访问B数据库等,都可以使用动 ...
- Spring boot Mybatis 整合(完整版)
个人开源项目 springboot+mybatis+thymeleaf+docker构建的个人站点开源项目(集成了个人主页.个人作品.个人博客) 朋友自制的springboot接口文档组件swagge ...
随机推荐
- sql 注入风险
目录 sql 注入风险 什么是sql注入呢? 查看sql注入风险 如何避免 sql 注入风险 pymysql 简单规避注入风险示列 sql 注入风险 什么是sql注入呢? 参考百度 查看sql注入风险 ...
- iOS加解密最重要的干货:CCCrypt
需要引入框架#import <CommonCrypto/CommonCryptor.h> 函数定义: CCCryptorStatus CCCrypt( CCOperation op, /* ...
- Jmeter学习笔记(十二)——断言
一.断言简介 jmeter中有个元件叫做断言(Assertion).用于检查测试中得到的响应数据等是否符合预期,用以保证性能测试过程中的数据交互与预期一致. 使用断言的目的:在request的返回层面 ...
- UCOSIII信号量
信号量通常分为两种 二进制信号量 计数型信号量 二进制信号量 二进制信号量只能取0和1两个值 计数型信号量 计数型信号量的范围由OS_SEM_CTR决定.OS_SEM_CTR可以为8位,16位和32位 ...
- Android应用通过JDBC直连阿里云MySQL数据库
1.设置白名单,获取外网连接地址 外部设备要访问阿里云MySQL数据库,则需要设置白名单,具体操作链接: https://help.aliyun.com/document_detail/43185.h ...
- MySQL Index--CREATE INDEX在各版本的优化
FIC(Fast index creation)特性在MySQL 5.5版本中引入FIC(Fast index creation)特性,创建索引时无需再拷贝整表数据,以提升索引的创建速度. FCI 操 ...
- Hadoop 二次排序
需求 求每年的最高气温,年份升序,温度求最高 数据源内容如下 temperature.txt 2004 49 1981 -22 1981 -31 1965 -47 2027 -2 1964 6 203 ...
- AngularJs中Uncaught Error: [$injector:modulerr] http://errors.angularjs.org/1.3.15/
我在使用angularjs的时候报出来这个错误: Uncaught Error: [$injector:modulerr] http://errors.angularjs.org/1.3.15/ 当时 ...
- 《The One!团队》第八次作业:ALPHA冲刺(二)
项目 内容 作业所属课程 所属课程 作业要求 作业要求 团队名称 < The One !> 作业学习目标 (1)掌握软件测试基础技术.(2)学习迭代式增量软件开发过程(Scrum) 第二天 ...
- Python爬取微信公众号素材库
这是我的之前写的代码,今天发布到博客园上,说不定以后需要用. 开始: #coding:utf-8 import werobot import pymongo class Gongzhonghao( ...