亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring Boot+Mybatis的整合過(guò)程

 更新時(shí)間:2017年07月07日 11:00:44   作者:hello_hjz  
這篇文章主要介紹了Spring Boot+Mybatis的整合過(guò)程,需要的朋友可以參考下

依賴配置

結(jié)合前面的內(nèi)容,這里我們要嵌入數(shù)據(jù)庫(kù)的操作,這里以操作MySQL為例整合Mybatis,首先需要在原來(lái)的基礎(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ū)動(dòng)以及返回json數(shù)據(jù)的json庫(kù)(格式化數(shù)據(jù))

<!-- MySql驅(qū)動(dòng) -->
<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庫(kù)的依賴 -->
  <dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>fastjson</artifactId>
  <version>1.1.43</version>
</dependency>

應(yīng)用配置

接著需要在application.properties中添加數(shù)據(jù)庫(kù)配置

#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ù)庫(kù)名叫weibo,其中表結(jié)構(gòu)如下:

這里寫圖片描述

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

這里寫圖片描述

編寫配置類

數(shù)據(jù)庫(kù)相關(guān)的DataSource,SqlSeesion配置,其中DataSourse的配置可以理解為解讀application.properties中的jdbc相關(guān)配置然后初始化JDBC驅(qū)動(dòng)的,SqlSeesion配置主要是針對(duì)Mybatis使用事務(wù)操作時(shí)的配置信息。

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ù)庫(kù)事務(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ù)表的過(guò)程,SprintBoot在運(yùn)行中會(huì)根據(jù)類上的@Mapper注解找到它,因此不能落下這個(gè)注解

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;
  }
}

最后運(yùn)行SpringBoot項(xiàng)目,然后在瀏覽器上輸入網(wǎng)址:

http://localhost:8080/diary?id=2

這樣即可看到結(jié)果

這里寫圖片描述 

到此SpringBoot+Mybatis的整合就完成了

源碼:https://github.com/huajianzh/spring/tree/master/springdemo

以上所述是小編給大家介紹的Spring Boot+Mybatis的整合過(guò)程,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Springboot整合Jedis實(shí)現(xiàn)單機(jī)版或哨兵版可切換配置方法

    Springboot整合Jedis實(shí)現(xiàn)單機(jī)版或哨兵版可切換配置方法

    這篇文章主要介紹了Springboot整合Jedis實(shí)現(xiàn)單機(jī)版或哨兵版可切換配置方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-11-11
  • Java 常見(jiàn)的限流算法詳細(xì)分析并實(shí)現(xiàn)

    Java 常見(jiàn)的限流算法詳細(xì)分析并實(shí)現(xiàn)

    大數(shù)據(jù)量高并發(fā)訪問(wèn)時(shí),經(jīng)常出現(xiàn)服務(wù)或接口面對(duì)暴漲的請(qǐng)求而不可用的情況,甚至引發(fā)連鎖反映導(dǎo)致整個(gè)系統(tǒng)崩潰。此時(shí)你需要使用的技術(shù)手段之一就是限流,當(dāng)請(qǐng)求達(dá)到一定的并發(fā)數(shù)或速率,就進(jìn)行等待、排隊(duì)、降級(jí)、拒絕服務(wù)等。限流時(shí),常見(jiàn)算法是計(jì)數(shù)器、漏斗、令牌桶算法
    2022-04-04
  • Java經(jīng)理與員工的差異實(shí)現(xiàn)方法

    Java經(jīng)理與員工的差異實(shí)現(xiàn)方法

    這篇文章主要介紹了Java經(jīng)理與員工的差異實(shí)現(xiàn)方法,需要的朋友可以參考下
    2014-03-03
  • 實(shí)現(xiàn)java簡(jiǎn)單的線程池

    實(shí)現(xiàn)java簡(jiǎn)單的線程池

    這篇文章主要為大家詳細(xì)介紹了java簡(jiǎn)單實(shí)現(xiàn)多線程,及java爬蟲使用線程池實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • IntelliJ IDEA 安裝 Grep Console插件 自定義控制臺(tái)輸出多顏色格式功能

    IntelliJ IDEA 安裝 Grep Console插件 自定義控制臺(tái)輸出多顏色格式功能

    由于Intellij idea不支持顯示ascii顏色,grep-console插件能很好的解決這個(gè)問(wèn)題,下面就以開發(fā)JavaEE項(xiàng)目中,結(jié)合Log4j配置多顏色日志輸出功能,感興趣的朋友一起看看吧
    2020-05-05
  • Jenkins如何實(shí)現(xiàn)自動(dòng)打包部署linux

    Jenkins如何實(shí)現(xiàn)自動(dòng)打包部署linux

    這篇文章主要介紹了Jenkins如何實(shí)現(xiàn)自動(dòng)打包部署linux,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Java匿名內(nèi)部類的寫法示例

    Java匿名內(nèi)部類的寫法示例

    這篇文章主要給大家介紹了關(guān)于Java匿名內(nèi)部類的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Java窗體動(dòng)態(tài)加載磁盤文件的實(shí)現(xiàn)方法

    Java窗體動(dòng)態(tài)加載磁盤文件的實(shí)現(xiàn)方法

    這篇文章主要介紹了Java窗體動(dòng)態(tài)加載磁盤文件的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2014-03-03
  • SpringBoot 錯(cuò)誤處理機(jī)制與自定義錯(cuò)誤處理實(shí)現(xiàn)詳解

    SpringBoot 錯(cuò)誤處理機(jī)制與自定義錯(cuò)誤處理實(shí)現(xiàn)詳解

    這篇文章主要介紹了SpringBoot 錯(cuò)誤處理機(jī)制與自定義錯(cuò)誤處理實(shí)現(xiàn)詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11
  • 詳解lombok @Getter @Setter 使用注意事項(xiàng)

    詳解lombok @Getter @Setter 使用注意事項(xiàng)

    這篇文章主要介紹了詳解lombok @Getter @Setter 使用注意事項(xiàng),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11

最新評(píng)論