欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot Mybatis 配置文件形式詳解

 更新時(shí)間:2023年03月23日 11:05:20   作者:ceaningking  
這篇文章主要介紹了SpringBoot Mybatis 配置文件形式詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

開(kāi)發(fā)環(huán)境: IDEA 2022.1.4+ Mybatis

1. 概述

        在之前BiliBili學(xué)習(xí)SprintBoot時(shí)候,按照視頻敲代碼,SpringBoot集成MyBatis,是單獨(dú)寫(xiě)了一個(gè)mybatis-config.xml文件。配置數(shù)據(jù)連接以及mapper等信息。后來(lái)問(wèn)了下從事Java得同事,告知mybatis-config.xml文件其實(shí)可以寫(xiě)到application.yml。當(dāng)時(shí)也沒(méi)弄清楚。后來(lái)摸索中,也就漸漸明白了。

2. 單獨(dú)配置mybatis-config.xml

2.1 配置內(nèi)容

        當(dāng)時(shí)視頻學(xué)習(xí),也寫(xiě)下學(xué)習(xí)得總結(jié)。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<!--configuration核心配置文件-->
<!--順序 properties->settings->typeAliases->typeHandlers->objectFactory->objectWrapperFactory->reflectorFactory->plugins->environments->databaseIdProvider->mappers-->
<configuration>
    <!--jdbc.properties配置文件-->
    <properties resource="jdbc.properties"></properties>
 
    <!--設(shè)置mybatis輸出日志 Mybatis默認(rèn)就是STDOUT_LOGGING-->
    <settings>
        <setting name="logImpl" value="STDOUT_LOGGING"/>
    </settings>
 
    <!--  類型別名 默認(rèn)為類名 指定這個(gè)后 mapper的xml文件指定返回值時(shí)候 可直接寫(xiě)類名(不區(qū)分大小寫(xiě)) 建議直接拷貝類名  -->
    <typeAliases>
        <package name="com.ceaning.crudp.entity"/>
    </typeAliases>
 
    <!-- 環(huán)境配置 -->
    <!-- development IDEA默認(rèn) 開(kāi)發(fā)環(huán)境 -->
    <!-- 可以自定義 比如定義test formal 看心情 每個(gè)SqlSessionFactory實(shí)例只能選擇一種環(huán)境 這個(gè)可隨時(shí)配置 -->
    <!-- test 測(cè)試環(huán)境 -->
    <!-- formal 正式環(huán)境 -->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>
    <!-- 映射器 每一個(gè)mapper.xml都需要在Mybatis的核心文件中注冊(cè)! -->
    <!-- 注冊(cè)方式1 使用xml文件 <mapper resource="com/ceaning/efmis/mapper/UserMapper.xml"/> -->
    <!-- 注冊(cè)方式2 使用class文件 <mapper class="com.ceaning.efmis.mapper.UserMapper"/> -->
    <!-- 注冊(cè)方式3 mapper代理方式 <package name="com.ceaning.efmis.mapper"/> -->
    <!--
        注冊(cè)方式2(使用class文件)和注冊(cè)方式3(使用包掃描注冊(cè))
        1.接口和他的Mapper配置文件必須同名
        2.接口和他的Mapper配置文件必須在同一個(gè)包下
    -->
    <mappers>
        <package name="com.ceaning.crudp.mapper"/>
    </mappers>
</configuration>

        jdbc.properties內(nèi)容如下:

        單獨(dú)寫(xiě)jdbc得配置,是擔(dān)心以后要是部署成WAR形式,修改mybatis-config.xml內(nèi)容得話,內(nèi)容太多,防止修改錯(cuò),就單獨(dú)搞個(gè)jdbc配置。(其實(shí)我想多了)

driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
url=jdbc:sqlserver://127.0.0.1:1433;databaseName=EFMIS
username=sa
password=123qwe,.

2.2 輔助類

        輔助類得作用在于初始調(diào)用類得時(shí)候,實(shí)現(xiàn)配置加載,并創(chuàng)建SqlSessionFactory,方便后面進(jìn)行SQL查詢。

public class MybatisUtils {
    //SqlSessionFactory 靜態(tài)單例模式
    private static SqlSessionFactory sqlSessionFactory;
 
    //使用Mybatis第一步 獲取SqlSessionFactory對(duì)象
    static {
        try{
            String resource="mybatis-config.xml";
            InputStream inputStream= Resources.getResourceAsStream(resource);
            sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream);
        } catch (Exception e){
            e.printStackTrace();
        }
    }
 
    //獲取SqlSession實(shí)例
    //該實(shí)例包含了面向數(shù)據(jù)庫(kù)執(zhí)行sql命令所需要的所有方法
    public static SqlSession getSqlSession(){
        return sqlSessionFactory.openSession();
    }
}

2.3 調(diào)用操作

        此處我以登錄操作為例。這樣就可以連接數(shù)據(jù)庫(kù)進(jìn)行操作。

@PostMapping("/user/login")
    public Result<?> login(@RequestBody User user){
        SqlSession sqlSession= null;
        Map<String, Object> map= new HashMap<>();
        try{
            sqlSession= MybatisUtils.getSqlSession();
            UserMapper mapper= sqlSession.getMapper(UserMapper.class);
            user= mapper.login(user);
            if (user!= null){
                //生成token
                Map<String, String> tokenmap= new HashMap<>();
                tokenmap.put("loginname", user.getLoginname());
                tokenmap.put("password", user.getPassword());
                String token= JwtUtils.getToken(tokenmap);
                //返回?cái)?shù)據(jù)
                map.put("user", user);
                map.put("token", token);
                return Result.ok(map);
            } else {
                return Result.error(CommonConstant.SYS_ERR_CODE, "用戶不存在!");
            }
        } catch (Exception e){
            e.printStackTrace();
            return Result.error("異常!"+ e.getMessage());
        } finally {
            if (sqlSession!= null){
                sqlSession.close();
            }
        }
    }

3. application.yml配置mybatis

3.1 配置內(nèi)容

        多余得內(nèi)容不用管它。主要是配置數(shù)據(jù)源spring.datasource。配置數(shù)據(jù)庫(kù)連接信息。

 
Server:
  port: 8090
 
spring:
  # quartz定時(shí)任務(wù)配置
  quartz:
    # 數(shù)據(jù)庫(kù)存儲(chǔ)方式
    job-store-type: jdbc
    org:
      quartz:
        jobStore:
          class: org.springframework.scheduling.quartz.LocalDataSourceJobStore
  #配置數(shù)據(jù)源
  datasource:
    url: jdbc:sqlserver://127.0.0.1:1433;SelectMethod=cursor;databaseName=EFMIS
    username: sa
    password: 123qwe,.
    driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
  #json
  jackson:
    date-format: yyyy-MM-dd HH:mm:ss
    time-zone: GMT+8
  #熱部署
  devtools:
    restart:
      enabled: true
      additional-paths: src/main/java
      exclude: static/**
  jta:
    atomikos:
      properties:
        recovery:
          forget-orphaned-log-entries-delay:
mybatis:
  configuration:
    #開(kāi)啟駝峰映射
    map-underscore-to-camel-case: true
    #開(kāi)啟緩存
    cache-enabled: true
  #加載mapper.xml文件
  mapper-locations: classpath:com/ceaning/crudp/mapper/*.xml
  #別名掃描
  type-aliases-package: com.ceaning.crudp.entity
logging:
  config: classpath:logback-spring.xml

3.2 輔助類

@Component
public class SpringUtils implements BeanFactoryPostProcessor {
    /**
     * Spring應(yīng)用上下文環(huán)境
     */
    private static ConfigurableListableBeanFactory beanFactory;
 
 
    @Override
    public void postProcessBeanFactory(ConfigurableListableBeanFactory configurableListableBeanFactory) throws BeansException {
        SpringUtils.beanFactory= configurableListableBeanFactory;
    }
 
    public static <T> T getBean(String name) throws BeansException{
        name= lowerCaseInit(name);
        if(containsBean(name)){
            return (T) beanFactory.getBean(name);
        } else{
            return null;
        }
    }
 
    /**
     * 獲取
     * @param cls
     * @return
     * @param <T>
     * @throws BeansException
     */
    public static <T> T getBean(Class<T> cls) throws BeansException{
        T result= (T) beanFactory.getBean(cls);
        return result;
    }
 
    /**
     * 判斷 BeanFactory是否包含bean對(duì)象
     * @param name
     * @return
     */
    public static boolean containsBean(String name){
        return beanFactory.containsBean(name);
    }
 
    /**
     * 判斷以給定名字注冊(cè)的bean定義是一個(gè)singleton還是一個(gè)prototype。
     * 如果與給定名字相應(yīng)的bean定義沒(méi)有被找到,將會(huì)拋出一個(gè)異常(NoSuchBeanDefinitionException)
     * @param name
     * @return
     * @throws NoSuchBeanDefinitionException
     */
    public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException{
        return beanFactory.isSingleton(name);
    }
 
    public static Class<?> getType(String name) throws NoSuchBeanDefinitionException{
        return beanFactory.getType(name);
    }
 
    public static String[] getAliases(String name) throws NoSuchBeanDefinitionException{
        return beanFactory.getAliases(name);
    }
 
    /**
     * 首字母小寫(xiě)
     * @param name
     * @return
     */
    private static String lowerCaseInit(String name){
        if(name.length()>0){
            char c= name.charAt(0);
            if(c>=65 && c<=90){
                int i= c+ 32;
                return ((char)i)+ name.substring(1);
            } else{
                return name;
            }
        } else{
            return null;
        }
    }
}

3.3 調(diào)用操作

        此處還是以登錄操作為例。同樣可以進(jìn)行數(shù)據(jù)庫(kù)連接操作。

@PostMapping("/user/login")
    public Result<?> login(@RequestBody User user){
        Map<String, Object> map= new HashMap<>();
        try{
            UserMapper mapper= SpringUtils.getBean(UserMapper.class);
            user= mapper.login(user);
            if (user!= null){
                //生成token
                Map<String, String> tokenmap= new HashMap<>();
                tokenmap.put("loginname", user.getLoginname());
                tokenmap.put("password", user.getPassword());
                String token= JwtUtils.getToken(tokenmap);
                //返回?cái)?shù)據(jù)
                map.put("user", user);
                map.put("token", token);
                return Result.ok(map);
            } else {
                return Result.error(CommonConstant.SYS_ERR_CODE, "用戶不存在!");
            }
        } catch (Exception e){
            e.printStackTrace();
            return Result.error("異常!"+ e.getMessage());
        } 
    }

4. 結(jié)語(yǔ)

        實(shí)際項(xiàng)目中單獨(dú)配置mybatis-config.xml較少。一般都寫(xiě)在application.yml里。

        后面繼續(xù)學(xué)習(xí)druid得配置以及操作實(shí)現(xiàn)。

到此這篇關(guān)于SpringBoot Mybatis 配置文件形式的文章就介紹到這了,更多相關(guān)SpringBoot Mybatis 配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Maven安裝過(guò)程圖文詳解

    Maven安裝過(guò)程圖文詳解

    這篇文章主要介紹了Maven安裝過(guò)程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-07-07
  • 深入理解Java中觀察者模式與委托的對(duì)比

    深入理解Java中觀察者模式與委托的對(duì)比

    這篇文章主要介紹了Java中觀察者模式與委托的對(duì)比,觀察者模式:定義了一種一對(duì)多的依賴關(guān)系,讓多個(gè)觀察者對(duì)象同時(shí)監(jiān)聽(tīng)某一個(gè)主題對(duì)象,委托的實(shí)現(xiàn)簡(jiǎn)單來(lái)講就是用反射來(lái)實(shí)現(xiàn)的,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • spring boot整合log4j2及MQ消費(fèi)處理系統(tǒng)日志示例

    spring boot整合log4j2及MQ消費(fèi)處理系統(tǒng)日志示例

    這篇文章主要為大家介紹了spring boot整合log4j2及MQ消費(fèi)處理系統(tǒng)日志的示例過(guò)程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • Java結(jié)合redis實(shí)現(xiàn)接口防重復(fù)提交

    Java結(jié)合redis實(shí)現(xiàn)接口防重復(fù)提交

    本文主要介紹了Java結(jié)合redis實(shí)現(xiàn)接口防重復(fù)提交,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 基于Gradle搭建Spring?5.3.13-release源碼閱讀環(huán)境的詳細(xì)流程

    基于Gradle搭建Spring?5.3.13-release源碼閱讀環(huán)境的詳細(xì)流程

    這篇文章主要介紹了基于Gradle搭建Spring?5.3.13-release源碼閱讀環(huán)境,首先安裝jdk、gradle等一系列必要操作,本文通過(guò)實(shí)例代碼相結(jié)合給大家講解的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • java開(kāi)發(fā)中常遇到的各種難點(diǎn)以及解決思路方案

    java開(kāi)發(fā)中常遇到的各種難點(diǎn)以及解決思路方案

    Java項(xiàng)目是一個(gè)復(fù)雜的軟件開(kāi)發(fā)過(guò)程,其中會(huì)涉及到很多技術(shù)難點(diǎn),這篇文章主要給大家介紹了關(guān)于java開(kāi)發(fā)中常遇到的各種難點(diǎn)以及解決思路方案的相關(guān)資料,需要的朋友可以參考下
    2023-07-07
  • Java多線程中的Balking模式詳解

    Java多線程中的Balking模式詳解

    大家好,本篇文章主要講的是Java多線程中的Balking模式詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • Java if-else 多重嵌套的優(yōu)化方式

    Java if-else 多重嵌套的優(yōu)化方式

    這篇文章主要介紹了Java if-else 多重嵌套的優(yōu)化方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • SpringCloud的Config配置中心詳解

    SpringCloud的Config配置中心詳解

    這篇文章主要介紹了SpringCloud的Config配置中心詳解,SpringCloud Config為微服務(wù)架構(gòu)中的微服務(wù)提供集中化的外部配置支持,配置服務(wù)器為各個(gè)不同微服務(wù)應(yīng)用的所有環(huán)境提供了一個(gè)中心化的外部配置,需要的朋友可以參考下
    2023-07-07
  • Guava輕松創(chuàng)建和管理不可變集合方法技巧

    Guava輕松創(chuàng)建和管理不可變集合方法技巧

    這篇文章主要為大家介紹了Guava輕松創(chuàng)建和管理不可變集合方法技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12

最新評(píng)論