Springboot 整合 Mybatis 的完整 Web 案例
发布日期:2022-01-31 20:00:19 浏览次数:32 分类:技术文章

本文共 5271 字,大约阅读时间需要 17 分钟。

一、运行 springboot-mybatis 工程

git clone 下载工程 
 ,项目地址见 
。下面开始运行工程步骤(Quick Start):
1.数据库准备
a.创建数据库 springbootdb:
CREATE DATABASE springbootdb;
b.创建表 city :
DROP TABLE IF EXISTS  `city`;CREATE TABLE `city` (  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '城市编号',  `province_id` int(10) unsigned  NOT NULL COMMENT '省份编号',  `city_name` varchar(25) DEFAULT NULL COMMENT '城市名称',  `description` varchar(25) DEFAULT NULL COMMENT '描述',  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
c.插入数据
INSERT city VALUES (1 ,1,'温岭市','BYSocket 的家在温岭。');
2. 项目结构介绍
org.spring.springboot.controller – Controller 层
org.spring.springboot.dao – 数据操作层 DAO
org.spring.springboot.domain – 实体类
org.spring.springboot.service – 业务逻辑层
Application – 应用启动类
application.properties – 应用配置文件,应用启动会自动读取配置
3.改数据库配置
打开 application.properties 文件, 修改相应的数据源配置,比如数据源地址、账号、密码等。(如果不是用 MySQL,自行添加连接驱动 pom,然后修改驱动名配置。)
4.编译工程
在项目根目录 springboot-learning-example,运行 maven 指令:
mvn clean install
5.运行工程

右键运行 Application 应用启动类的 main 函数,然后在浏览器访问:

http://localhost:8080/api/city?cityName=温岭市
可以看到返回的 JSON 结果:
{    "id": 1,    "provinceId": 1,    "cityName": "温岭市",    "description": "我的家在温岭。"}
如图:

二、springboot-mybatis 工程配置详解

org.mybatis.spring.boot
mybatis-spring-boot-starter
${mybatis-spring-boot}
mybatis-spring-boot-starter 工程依赖如图:
整个工程的 pom.xml:
4.0.0
springboot
springboot-mybatis
0.0.1-SNAPSHOT
springboot-mybatis :: 整合 Mybatis Demo
org.springframework.boot
spring-boot-starter-parent
1.5.1.RELEASE
1.2.0
5.1.39
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-test
test
org.mybatis.spring.boot
mybatis-spring-boot-starter
${mybatis-spring-boot}
mysql
mysql-connector-java
${mysql-connector}
junit
junit
4.12
2.在 application.properties 应用配置文件,增加 Mybatis 相关配置
## Mybatis 配置mybatis.typeAliasesPackage=org.spring.springboot.domainmybatis.mapperLocations=classpath:mapper/*.xml
mybatis.typeAliasesPackage 配置为 org.spring.springboot.domain,指向实体类包路径。mybatis.mapperLocations 配置为 classpath 路径下 mapper 包下,* 代表会扫描所有 xml 文件。
mybatis 其他配置相关详解如下:
mybatis.config = mybatis 配置文件名称
mybatis.mapperLocations = mapper xml 文件地址
mybatis.typeAliasesPackage = 实体类包路径
mybatis.typeHandlersPackage = type handlers 处理器包路径
mybatis.check-config-location = 检查 mybatis 配置是否存在,一般命名为 mybatis-config.xml
mybatis.executorType = 执行模式。默认是 SIMPLE
3.在 Application 应用启动类添加注解 MapperScan
Application.java 代码如下:
/** * Spring Boot 应用启动类 * * Created by bysocket on 16/4/26. */// Spring Boot 应用的标识@SpringBootApplication// mapper 接口类扫描包配置@MapperScan("org.spring.springboot.dao")public class Application {     public static void main(String[] args) {        // 程序启动入口        // 启动嵌入式的 Tomcat 并初始化 Spring 环境及其各 Spring 组件        SpringApplication.run(Application.class,args);    }}
mapper 接口类扫描包配置注解 MapperScan :用这个注解可以注册 Mybatis mapper 接口类。
4.添加相应的 City domain类、CityDao mapper接口类

City.java:

/** * 城市实体类 * * Created by bysocket on 07/02/2017. */public class City {     /**     * 城市编号     */    private Long id;     /**     * 省份编号     */    private Long provinceId;     /**     * 城市名称     */    private String cityName;     /**     * 描述     */    private String description;     public Long getId() {        return id;    }     public void setId(Long id) {        this.id = id;    }     public Long getProvinceId() {        return provinceId;    }     public void setProvinceId(Long provinceId) {        this.provinceId = provinceId;    }     public String getCityName() {        return cityName;    }     public void setCityName(String cityName) {        this.cityName = cityName;    }     public String getDescription() {        return description;    }     public void setDescription(String description) {        this.description = description;    }}
CityDao.java:
/** * 城市 DAO 接口类 * * Created by bysocket on 07/02/2017. */public interface CityDao {     /**     * 根据城市名称,查询城市信息     *     * @param cityName 城市名     */    City findByName(@Param("cityName") String cityName);}
其他不明白的,可以 git clone 下载工程 
 ,工程代码注解很详细。 

三、其他

利用 Mybatis-generator自动生成代码
Mybatis 通用 Mapper3 
Mybatis 分页插件 PageHelper 
最后,推荐阅读:《 

转载地址:https://blog.csdn.net/qq_23315711/article/details/72625141 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:DataTables介绍
下一篇:本地更新代码同步至github仓库

发表评论

最新留言

能坚持,总会有不一样的收获!
[***.219.124.196]2024年04月18日 04时17分58秒