Spring Boot+Mybatis的整合過程
依賴配置
結(jié)合前面的內(nèi)容,這里我們要嵌入數(shù)據(jù)庫的操作,這里以操作MySQL為例整合Mybatis,首先需要在原來的基礎(chǔ)上添加以下依賴
<!-- mybatis依賴 --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.1.1</version> </dependency>
當(dāng)然啦,只依賴mybatis是不夠的還需要依賴jdbc驅(qū)動以及返回json數(shù)據(jù)的json庫(格式化數(shù)據(jù))
<!-- MySql驅(qū)動 --> <dependency> <groupId>org.apache.tomcat</groupId> <artifactId>tomcat-jdbc</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.21</version> </dependency> <!--Json庫的依賴 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.1.43</version> </dependency>
應(yīng)用配置
接著需要在application.properties中添加數(shù)據(jù)庫配置
#JDBC配置 spring.datasource.url=jdbc:mysql://127.0.0.1:3306/weibo?useUnicode=true&characterEncoding=gbk&zeroDateTimeBehavior=convertToNull spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver
這里連接的數(shù)據(jù)庫名叫weibo,其中表結(jié)構(gòu)如下:

接下來就需要來具體的初始化MyBatis配置以及數(shù)據(jù)表的操作了,先看一下工程結(jié)構(gòu)

編寫配置類
數(shù)據(jù)庫相關(guān)的DataSource,SqlSeesion配置,其中DataSourse的配置可以理解為解讀application.properties中的jdbc相關(guān)配置然后初始化JDBC驅(qū)動的,SqlSeesion配置主要是針對Mybatis使用事務(wù)操作時的配置信息。
package com.example.demo.config;
import javax.sql.DataSource;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.PlatformTransactionManager;
@EnableAutoConfiguration
@ComponentScan
@MapperScan("com.example.demo.mapper")
public class JdbcConfig {
// DataSource配置
@Bean
@ConfigurationProperties(prefix = "spring.datasource")
public DataSource dataSource() {
return new org.apache.tomcat.jdbc.pool.DataSource();
}
// 提供SqlSeesion(數(shù)據(jù)庫事務(wù)操作相關(guān)的配置)
@Bean
public SqlSessionFactory sqlSessionFactoryBean() throws Exception {
SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
sqlSessionFactoryBean.setDataSource(dataSource());
PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
sqlSessionFactoryBean.setMapperLocations(resolver.getResources("classpath:/mybatis/*.xml"));
return sqlSessionFactoryBean.getObject();
}
@Bean
public PlatformTransactionManager transactionManager() {
return new DataSourceTransactionManager(dataSource());
}
}
添加Pojo類
該類主要接收數(shù)據(jù)表中的數(shù)據(jù),所以屬性基本上跟數(shù)據(jù)表的屬性一致
package com.example.demo.bean;
public class Diary {
private int id;
private String title;
private String content;
private String pubTime;
private int userId;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getContent() {
return content;
}
public void setContent(String content) {
this.content = content;
}
public String getPubTime() {
return pubTime;
}
public void setPubTime(String pubTime) {
this.pubTime = pubTime;
}
public int getUserId() {
return userId;
}
public void setUserId(int userId) {
this.userId = userId;
}
@Override
public String toString() {
return "Diary [id=" + id + ", title=" + title + ", content=" + content + ", pubTime=" + pubTime + ", userId="
+ userId + "]";
}
}
添加數(shù)據(jù)表操作接口
該類描述了操作數(shù)據(jù)表的過程,SprintBoot在運行中會根據(jù)類上的@Mapper注解找到它,因此不能落下這個注解
package com.example.demo.mapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import com.example.demo.bean.Diary;
@Mapper
public interface DiaryMapper {
@Select("select * from diary where _id = #{id}")
public Diary getDiaryById(@Param("id")Integer id);
}
使用
package com.example.demo.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.alibaba.fastjson.JSON;
import com.example.demo.bean.Diary;
import com.example.demo.mapper.DiaryMapper;
@RestController
public class DiaryMappingController {
@Autowired
DiaryMapper diaryMapper;
@RequestMapping("/diary")
public String getDiary(Integer id){
Diary d = diaryMapper.getDiaryById(id);
String json = JSON.toJSONString(d);
return json;
}
}
最后運行SpringBoot項目,然后在瀏覽器上輸入網(wǎng)址:
http://localhost:8080/diary?id=2
這樣即可看到結(jié)果
到此SpringBoot+Mybatis的整合就完成了
源碼:https://github.com/huajianzh/spring/tree/master/springdemo
以上所述是小編給大家介紹的Spring Boot+Mybatis的整合過程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Springboot整合Jedis實現(xiàn)單機(jī)版或哨兵版可切換配置方法
這篇文章主要介紹了Springboot整合Jedis實現(xiàn)單機(jī)版或哨兵版可切換配置方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-11-11
IntelliJ IDEA 安裝 Grep Console插件 自定義控制臺輸出多顏色格式功能
由于Intellij idea不支持顯示ascii顏色,grep-console插件能很好的解決這個問題,下面就以開發(fā)JavaEE項目中,結(jié)合Log4j配置多顏色日志輸出功能,感興趣的朋友一起看看吧2020-05-05
Java窗體動態(tài)加載磁盤文件的實現(xiàn)方法
這篇文章主要介紹了Java窗體動態(tài)加載磁盤文件的實現(xiàn)方法,需要的朋友可以參考下2014-03-03
SpringBoot 錯誤處理機(jī)制與自定義錯誤處理實現(xiàn)詳解
這篇文章主要介紹了SpringBoot 錯誤處理機(jī)制與自定義錯誤處理實現(xiàn)詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
詳解lombok @Getter @Setter 使用注意事項
這篇文章主要介紹了詳解lombok @Getter @Setter 使用注意事項,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11

