SpringBoot数据访问之整合mybatis注解版
SpringBoot数据访问之整合mybatis注解版
mybatis注解版:
贴心链接:Github
在网页下方,找到快速开始文档
上述链接方便读者查找。
通过快速开始文档,搭建环境:
创建数据库:
use vuesite;
CREATE TABLE city
(
id INT PRIMARY KEY auto_increment,
name VARCHAR(255),
state VARCHAR(255),
country VARCHAR(255)
);
创建实体类:
package com.xbhog.pojo;
import lombok.Data;
@Data
public class City {
private Long id;
private String name;
private String state;
private String country;
}
创建Mapper:
创建CityMapper并采用注解的方式实现sql映射的问题:
package com.xbhog.Mapper;
import com.xbhog.pojo.City;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
@Mapper
public interface CityMapper {
@Select("select * from user where id = #{id}")
public City getCityId(Long id);
}
创建Service:
package com.xbhog.service;
import com.xbhog.Mapper.CityMapper;
import com.xbhog.pojo.City;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class CityService {
@Autowired
CityMapper cityMapper;
public City getCityId(Long id){
return cityMapper.getCityId(id);
}
}
使用Service注解声明,并将该类加入到容器中,方便后面调用,在service层调用Mapper层的方法。
创建Controller:
import com.xbhog.pojo.City;
import com.xbhog.service.CityService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.annotation.Resource;
@Controller
public class Mycontro {
@Autowired
CityService cityService;
@ResponseBody
@GetMapping("/city")
public City getCity(@RequestParam("id") Long id){
return cityService.getCityId(id);
}
}
增加数据库信息:
测试:
mybatis混合版:
我们在CItyMapper中添加一个方法:
package com.xbhog.Mapper;
import com.xbhog.pojo.City;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import java.util.List;
@Mapper
public interface CityMapper {
@Select("select * from city where id = #{id}")
public City getCityId(Long id);
public void addCity(City city);
}
这个方法我们采用配置文件来绑定。
创建CityMapper.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.xbhog.Mapper.CityMapper">
<insert id="addCity" parameterType="com.xbhog.pojo.City">
insert into city(`name`,`state`,`country`) values (#{name},#{state},#{country});
</insert>
</mapper>
其中命名空间与CityMapper要对应,进行插入操作。
在Service层增加方法:
package com.xbhog.service;
import com.xbhog.Mapper.CityMapper;
import com.xbhog.pojo.City;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class CityService {
@Autowired
CityMapper cityMapper;
public void addCity(City city){
cityMapper.addCity(city);
}
}
在Controller中增加方法:
import com.xbhog.pojo.City;import com.xbhog.service.CityService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.PostMapping;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.ResponseBody;import javax.annotation.Resource;@Controllerpublic class Mycontro { @Autowired CityService cityService; @ResponseBody @PostMapping("/add") public City addcity(City city){ cityService.addCity(city); return city; }}
通过返回的city来查看信息是否正确。
测试:
我们通过PostMan来发送请求信息进行测试。
请求的方式为Post,url就是我们Controller中的add请求。post提交的参数:name、state、country。
会自动封装为City。
从上图可以发现,我们的id是Null,怎么样让添加后的数据返回id呢,在Mybatis中有useGeneratedKeys自增主键,自增主键的名字叫id。
这样添加进去的数据就会将id返回给传入的city中的id。
<insert id="addCity" parameterType="com.xbhog.pojo.City" useGeneratedKeys="true" keyProperty="id"> insert into city(`name`,`state`,`country`) values (#{name},#{state},#{country});</insert>
也可以采用注解的方式实现:
import com.xbhog.pojo.City;import org.apache.ibatis.annotations.Insert;import org.apache.ibatis.annotations.Mapper;import org.apache.ibatis.annotations.Options;import org.apache.ibatis.annotations.Select;import java.util.List;@Mapperpublic interface CityMapper { @Select("select * from city where id = #{id}") public City getCityId(Long id); @Insert("insert into city(`name`,`state`,`country`) values (#{name},#{state},#{country})") @Options(useGeneratedKeys = true,keyProperty = "id") public void addCity(City city);}
public City addcity(City city){ //city -->id有值了 cityService.addCity(city); return city; }
查看效果:
参考文献:
官网:Github
结束:
如果你看到这里或者正好对你有所帮助,希望能点个关注或者推荐,感谢;
有错误的地方,欢迎在评论指出,作者看到会进行修改。
SpringBoot数据访问之整合mybatis注解版的更多相关文章
- SpringBoot数据访问之整合Mybatis配置文件
环境搭建以及前置知识回顾 SpringBoot中有两种start的形式: 官方:spring-boot-starter-* 第三方:*-spring-boot-starter Mybatis属于第三方 ...
- SpringBoot整合Mybatis注解版---update出现org.apache.ibatis.binding.BindingException: Parameter 'XXX' not found. Available parameters are [arg1, arg0, param1, param2]
SpringBoot整合Mybatis注解版---update时出现的问题 问题描述: 1.sql建表语句 DROP TABLE IF EXISTS `department`; CREATE TABL ...
- java框架之SpringBoot(9)-数据访问及整合MyBatis
简介 对于数据访问层,无论是 SQL 还是 NOSQL,SpringBoot 默认采用整合 SpringData 的方式进行统一处理,添加了大量的自动配置,引入了各种 Template.Reposit ...
- Spring Boot数据访问之整合Mybatis
在Mybatis整合Spring - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)中谈到了Spring和Mybatis整合需要整合的点在哪些方面,需要将Mybatis中数据库连接池等相关对 ...
- SpringBoot整合MyBatis(注解版)
详情可以参考Mybatis官方文档 http://www.mybatis.org/spring-boot-starter/mybatis-spring-boot-autoconfigure/ (1). ...
- 【串线篇】SpringBoot数据访问【数据源/mybatis/指定映射文件位置】
一.配置数据源 1.1.jdbc版本 JDBC(.tomcat.jdbc.pool.DataSource作为数据源) <?xml version="1.0" encoding ...
- Spring Boot2 系列教程 (十三) | 整合 MyBatis (XML 版)
前言 如题,今天介绍 SpringBoot 与 Mybatis 的整合以及 Mybatis 的使用,之前介绍过了 SpringBoot 整合MyBatis 注解版的使用,上一篇介绍过 MyBatis ...
- SpringBoot Mybatis整合(注解版),SpringBoot集成Mybatis(注解版)
SpringBoot Mybatis整合(注解版),SpringBoot集成Mybatis(注解版) ================================ ©Copyright 蕃薯耀 2 ...
- springboot整合mybatis(注解)
springboot整合mybatis(注解) 1.pom.xml: <?xml version="1.0" encoding="UTF-8"?> ...
随机推荐
- React组件三大属性之state
React组件三大属性之state 组件被称为"状态机", 页面的显示是根据组件的state属性的数据来显示 理解1) state是组件对象最重要的属性, 值是对象(可以包含多个数 ...
- noip模拟23[联·赛·题]
\(noip模拟23\;solutions\) 怎么说呢??这个考试考得是非常的惨烈,一共拿了70分,为啥呢 因为我第一题和第三题爆零了,然后第二题拿到了70分,还是贪心的分数 第一题和第二题我调了好 ...
- VScode中LeetCode插件无法登录的情况
VScode中LeetCode插件无法登录的情况 一直提示账户和密码无效,不知道什么问题. 后来发现是设置问题 在插件中找到leetcode 右键,点击setting 在界面里找到这里,将leetco ...
- Dijkstra和堆优化
Dijkstra算法 由于我之前一直记的迪杰斯特拉的翻译导致我把dijkstra写成了dijstra--所以下文#define dijstra dijkstra 我以后叫她迪杰克斯歘! Dijskra ...
- 2个Double字符串进行
public static int compare(double d1, double d2) { if (d1 < d2) return -1; // Neither val is NaN, ...
- Beego和Vue的前后端分离跨域问题处理
VUE封装的请求头(注意请求头,跨域要用到) 路径 utils/mereq.js import request from '@/utils/request' import qs from 'qs' e ...
- Hexo搭建静态博客站点
什么是Hexo? Hexo 是一个快速.简洁且高效的博客框架.Hexo 使用 Markdown(或其他渲染引擎)解析文章,在几秒内,即可利用靓丽的主题生成静态网页. 本文将介绍如何在没有域名和云主机的 ...
- springmvc学习指南 之---第24篇 国际化问题
writedby 张艳涛,今天一天就搞了一个这个问题,主要是下路,遇到springmvc-config.web的配置和拦截器的使用问题, 看了几天的spring发现都没讲拦截器,之前看了两天sprin ...
- ASP.NET中Textbox后的必填验证控件RequiredFieldValidator的使用方法。
制作效果如下: 实现方法: 1. 拖动RequiredFieldValidator控件到相应的textbox后位置,点击属性面板,输入ErroMessage相应信息,更改ForeColor为红色 设置 ...
- Python 爬取 ajax 返回的数据
1 from urllib.request import quote, unquote 2 import random 3 import requests 4 5 #quote 将单个字符串编码转化为 ...