Spring Boot 整合 Mybatis Annotation 注解的完整 Web 案例
摘要: 原創出處 www.bysocket.com 「泥瓦匠BYSocket 」歡迎轉載,保留摘要,謝謝!
『 公司需要人、產品、業務和方向,方向又要人、產品、業務和方向,方向… 循環』
本文提綱
一、前言
二、運行 springboot-mybatis-annotation 工程
三、springboot-mybatis-annotation 工程配置詳解
四、小結
運行環境:JDK 7 或 8、Maven 3.0+
技術棧:SpringBoot 1.5+、SpringBoot Mybatis Starter 1.2+ 、MyBatis 3.4+
前言
距離第一篇 Spring Boot 係列的博文 3 個月了。《Springboot 整合 Mybatis 的完整 Web 案例》第一篇出來是 XML 配置 SQL 的形式。雖然 XML 形式是我比較推薦的,但是注解形式也是方便的。尤其一些小係統,快速的 CRUD 輕量級的係統。
這裏感謝曉春 https://xchunzhao.tk/ 的 Pull Request,提供了 springboot-mybatis-annotation 的實現。
一、運行 springboot-mybatis-annotation 工程
由於這篇文章和 《Springboot 整合 Mybatis 的完整 Web 案例》 類似,所以運行這塊環境配置大家參考另外一篇兄弟文章。
然後Application 應用啟動類的 main 函數,然後在瀏覽器訪問:
1
|
http: //localhost:8080/api/city?cityName=溫嶺市
|
可以看到返回的 JSON 結果:
1
2
3
4
5
6
|
{ "id" : 1,
"provinceId" : 1,
"cityName" : "溫嶺市" ,
"description" : "我的家在溫嶺。"
} |
三、springboot-mybatis-annotation 工程配置詳解
1.pom 添加 Mybatis 依賴
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
<? xml version = "1.0" encoding = "UTF-8" ?>
< project xmlns = "https://maven.apache.org/POM/4.0.0" xmlns:xsi = "https://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "https://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" >
< modelVersion >4.0.0</ modelVersion >
< groupId >springboot</ groupId >
< artifactId >springboot-mybatis-annotation</ artifactId >
< version >0.0.1-SNAPSHOT</ version >
< packaging >jar</ packaging >
< name >springboot-mybatis-annotation</ name >
< description >Springboot-mybatis :: 整合Mybatis Annotation Demo</ description >
<!-- Spring Boot 啟動父依賴 -->
< parent >
< groupId >org.springframework.boot</ groupId >
< artifactId >spring-boot-starter-parent</ artifactId >
< version >1.5.1.RELEASE</ version >
</ parent >
< properties >
< mybatis-spring-boot >1.2.0</ mybatis-spring-boot >
< mysql-connector >5.1.39</ mysql-connector >
</ properties >
< dependencies >
<!-- Spring Boot Web 依賴 -->
< dependency >
< groupId >org.springframework.boot</ groupId >
< artifactId >spring-boot-starter-web</ artifactId >
</ dependency >
<!-- Spring Boot Test 依賴 -->
< dependency >
< groupId >org.springframework.boot</ groupId >
< artifactId >spring-boot-starter-test</ artifactId >
< scope >test</ scope >
</ dependency >
<!-- Spring Boot Mybatis 依賴 -->
< dependency >
< groupId >org.mybatis.spring.boot</ groupId >
< artifactId >mybatis-spring-boot-starter</ artifactId >
< version >${mybatis-spring-boot}</ version >
</ dependency >
<!-- MySQL 連接驅動依賴 -->
< dependency >
< groupId >mysql</ groupId >
< artifactId >mysql-connector-java</ artifactId >
< version >${mysql-connector}</ version >
</ dependency >
<!-- Junit -->
< dependency >
< groupId >junit</ groupId >
< artifactId >junit</ artifactId >
< version >4.12</ version >
</ dependency >
</ dependencies >
</ project >
|
2.在 CityDao 城市數據操作層接口類添加注解 @Mapper、@Select 和 @Results
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
/** * 城市 DAO 接口類 * * Created by xchunzhao on 02/05/2017. */ @Mapper // 標誌為 Mybatis 的 Mapper
public interface CityDao {
/** * 根據城市名稱,查詢城市信息 * * @param cityName 城市名 */ @Select ( "SELECT * FROM city" )
// 返回 Map 結果集 @Results ({
@Result (property = "id" , column = "id" ),
@Result (property = "provinceId" , column = "province_id" ),
@Result (property = "cityName" , column = "city_name" ),
@Result (property = "description" , column = "description" ),
}) City findByName( @Param ( "cityName" ) String cityName);
} |
@Mapper 標誌接口為 MyBatis Mapper 接口
@Select 是 Select 操作語句
@Results 標誌結果集,以及與庫表字段的映射關係
其他的注解可以看 org.apache.ibatis.annotations 包提供的,如圖:
可以 git clone 下載工程 springboot-learning-example ,springboot-mybatis-annotation 工程代碼注解很詳細。 https://github.com/JeffLi1993/springboot-learning-example。
四、小結
注解不涉及到配置,更近貼近 0 配置。再次感謝曉春 https://xchunzhao.tk/ 的 Pull Request~
歡迎掃一掃我的公眾號關注 — 及時得到博客訂閱哦!
— https://www.bysocket.com/ —
— https://github.com/JeffLi1993 —
最後更新:2017-05-13 08:41:16