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

Mybatis如何使用@Mapper和@MapperScan注解實(shí)現(xiàn)映射關(guān)系

 更新時(shí)間:2021年10月08日 12:04:19   作者:pan_junbiao  
這篇文章主要介紹了Mybatis使用@Mapper和@MapperScan注解實(shí)現(xiàn)映射關(guān)系,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

使用@Mapper和@MapperScan注解實(shí)現(xiàn)映射關(guān)系

MyBatis與Spring整合后需要實(shí)現(xiàn)實(shí)體和數(shù)據(jù)表的映射關(guān)系。

實(shí)現(xiàn)實(shí)體和數(shù)據(jù)表的映射關(guān)系可以在Mapper類上添加@Mapper注解,如下代碼:

/**
 * 用戶信息Mapper動(dòng)態(tài)代理接口
 * @author pan_junbiao
 **/
@Mapper
@Repository
public interface UserMapper
{
    /**
     * 新增用戶,并獲取自增主鍵
     */
    @Insert("INSERT INTO tb_user(user_account,user_password,blog_url,blog_remark) VALUES(#{userAccount},#{userPassword},#{blogUrl},#{blogRemark})")
    @Options(useGeneratedKeys = true, keyColumn = "user_id", keyProperty = "userId")
    //或者:@SelectKey(statement = "SELECT LAST_INSERT_ID()", keyColumn = "user_id", keyProperty = "userId",before = false, resultType = Integer.class)
    public int insertUser(UserInfo userInfo);
 
    /**
     * 修改用戶
     */
    @Update("UPDATE tb_user SET user_account = #{userAccount} ,user_password = #{userPassword} ,blog_url=#{blogUrl} ,blog_remark=#{blogRemark} WHERE user_id = #{userId}")
    public int updateUser(UserInfo userInfo);
 
    /**
     * 刪除用戶
     */
    @Delete("DELETE FROM tb_user WHERE user_id = #{userId}")
    public int deleteUser(int userId);
 
    /**
     * 根據(jù)用戶ID,獲取用戶信息
     */
    @Select("SELECT * FROM tb_user WHERE user_id = #{userId}")
    public UserInfo getUserById(int userId);
}

但是建議以后直接在SpringBoot啟動(dòng)類中加 @MapperScan("com.pjb.mapper") 注解,這樣會(huì)比較方便,不需要對(duì)每個(gè)Mapper都添加@Mapper注解。

package com.pjb;
 
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
 
/**
 * SpringBoot啟動(dòng)類
 * @author pan_junbiao
 **/
@MapperScan("com.pjb.mapper")
@SpringBootApplication
public class SpringbootMybatisDemoApplication
{
    public static void main(String[] args)
    {
        SpringApplication.run(SpringbootMybatisDemoApplication.class, args);
    }
}

Mybatis-@MapperScan和mybatis:scan分析

MyBatis-Spring-1.2.0 新增了兩種新的掃描映射器 Mapper 接口的方法:

  • 使用<mybatis:scan/>元素
  • 使用@MapperScan 注解(需要 Spring3.1+版本)

<mybatis:scan>

<mybatis:scan>元素將在特定的以逗號(hào)分隔的包名列表中搜索映射器 Mapper 接口。 使用這個(gè)新的 MyBatis-Spring 名空間你需要添加以下的 schema 聲明:

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mybatis="http://mybatis.org/schema/mybatis-spring"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://mybatis.org/schema/mybatis-spring
http://mybatis.org/schema/mybatis-spring.xsd">
<mybatis:scan base-package="com.mybatis.x.mappers" />
</beans>

<mybatis:scan> 元素提供了下列的屬性來自定義掃描過程:

  • annotation:掃描器將注冊(cè)所有的在 base-package 包內(nèi)并且匹配指定注解的映射器 Mapper 接口。
  • factory - ref:當(dāng) Spring 上下文中有多個(gè)SqlSessionFactory實(shí)例時(shí),需要指定某一特定的SqlSessionFactory 來創(chuàng)建映射器 Mapper 接口。正常情況下,只有應(yīng)用程序中有一個(gè)以上的數(shù)據(jù)源才會(huì)使用。
  • marker - interface:掃描器將注冊(cè)在 base-package 包中的并且繼承了特定的接口類的映射器 Mapper 接口
  • template - ref:當(dāng) Spring 上下文中有多個(gè) SqlSessionTemplate 實(shí)例時(shí),需要指定某一特定的SqlSessionTemplate 來創(chuàng)建映射器 Mapper 接口。 正常情況下,只有應(yīng)用程序中有一個(gè)以上的數(shù)據(jù)源才會(huì)使用。
  • name-generator:BeannameGenerator 類的完全限定類名,用來命名檢測(cè)到的組件。

MapperScan

Spring 3.x+版本支持使用@Configuration 和@Bean 注解來提供基于 Java 的配置。如果使用基于java的配置,可以使用@MapperScan 注解來掃描映射器 Mapper 接口。 @MapperScan 和<mybatis:scan/>工作方式

相同,并且也提供了對(duì)應(yīng)的自定義選項(xiàng)。

@Configuration
@MapperScan("com.mybatis.x.mappers")
public class AppConfig
{
@Bean
public DataSource dataSource()
{
return new PooledDataSource("com.mysql.jdbc.Driver",
"jdbc:mysql://localhost:3306/test", "root", "root");
}
@Bean
public SqlSessionFactory sqlSessionFactory() throws Exception
{
SqlSessionFactoryBeansessionFactory = new
SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource());
return sessionFactory.getObject();
}
}

@MapperScan 注解有以下屬性供自定義掃描過程使用:

  • annotationClass:掃描器將注冊(cè)所有的在 base-package 包內(nèi)并且匹配指定注解的映射器 Mapper 接口。
  • markerInterface:掃描器將注冊(cè)在 base-package 包中的并且繼承了特定的接口類的映射器 Mapper 接口
  • sqlSessionFactoryRef:當(dāng)Spring上下文中有一個(gè)以上的 SqlSesssionFactory時(shí),用來指定特 SqlSessionFactory
  • sqlSessionTemplateRef:當(dāng)Spring上下文中有一個(gè)以上的 sqlSessionTemplate時(shí),用來指定特定sqlSessionTemplate
  • nameGenerator:BeanNameGenerator 類用來命名在 Spring 容器內(nèi)檢測(cè)到的組件。
  • basePackageClasses:basePackages() 的類型安全的替代品。包內(nèi)的每一個(gè)類都會(huì)被掃描。
  • basePackages:掃描器掃描的基包,掃描器會(huì)掃描內(nèi)部的 Mapper 接口。注意包內(nèi)的至少有一個(gè)方法聲明的才會(huì)被注冊(cè)。具體類將會(huì)被忽略。

當(dāng)然還可以在 applicationContext.xml 配置如下

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.mybatis3.mappers" />
</bean>

使用 MapperScannerConfigurer 來掃描包 package ("com.mybatis3.mappers")下的所有 映射器 Mapper 接口,并自動(dòng)地注冊(cè)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java中數(shù)字黑洞實(shí)現(xiàn)代碼

    Java中數(shù)字黑洞實(shí)現(xiàn)代碼

    這篇文章主要介紹了Java編程中如何實(shí)現(xiàn)數(shù)字黑洞算法游戲,其中涉及到了數(shù)組、scanner、if語句等Java編程的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2017-09-09
  • java List去掉重復(fù)元素的幾種方式(小結(jié))

    java List去掉重復(fù)元素的幾種方式(小結(jié))

    這篇文章主要介紹了java List去掉重復(fù)元素的幾種方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • 全面了解JAVA_BaseDAO數(shù)據(jù)處理類

    全面了解JAVA_BaseDAO數(shù)據(jù)處理類

    下面小編就為大家?guī)硪黄媪私釰AVA_BaseDAO數(shù)據(jù)處理類。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-07-07
  • 深入理解Java原生的序列化機(jī)制

    深入理解Java原生的序列化機(jī)制

    Java 提供了一種對(duì)象序列化的機(jī)制,該機(jī)制中,一個(gè)對(duì)象可以被表示為一個(gè)字節(jié)序列,該字節(jié)序列包括該對(duì)象的數(shù)據(jù)、有關(guān)對(duì)象的類型的信息和存儲(chǔ)在對(duì)象中數(shù)據(jù)的類型。下面小編和大家來一起學(xué)習(xí)一下吧
    2019-06-06
  • 三道java新手入門面試題,通往自由的道路--JVM

    三道java新手入門面試題,通往自由的道路--JVM

    這篇文章主要為大家分享了最有價(jià)值的3道JVM面試題,涵蓋內(nèi)容全面,包括數(shù)據(jù)結(jié)構(gòu)和算法相關(guān)的題目、經(jīng)典面試編程題等,對(duì)hashCode方法的設(shè)計(jì)、垃圾收集的堆和代進(jìn)行剖析,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Java中方法優(yōu)先調(diào)用可選參數(shù)還是固定參數(shù)

    Java中方法優(yōu)先調(diào)用可選參數(shù)還是固定參數(shù)

    這篇文章主要介紹了Java中方法優(yōu)先調(diào)用可選參數(shù)還是固定參數(shù),可選參數(shù)是?JDK?5?中新增的特性,也叫變長參數(shù)或可變參數(shù),固定參數(shù)的概念恰好與可選參數(shù)相反,固定參數(shù)也就是普通的參,下文更多詳細(xì)內(nèi)容需要的小伙伴可以參考一下
    2022-05-05
  • 解決springboot自定義注解AOP在controller上導(dǎo)致controller注入失敗問題

    解決springboot自定義注解AOP在controller上導(dǎo)致controller注入失敗問題

    這篇文章主要介紹了解決springboot自定義注解AOP在controller上導(dǎo)致controller注入失敗問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Java預(yù)防SQL注入的具體實(shí)踐方法

    Java預(yù)防SQL注入的具體實(shí)踐方法

    在?Java?中預(yù)防?SQL?注入的核心是?避免直接拼接?SQL?語句,并通過參數(shù)化查詢、ORM?框架和嚴(yán)格的輸入驗(yàn)證來實(shí)現(xiàn)安全防護(hù),以下是具體實(shí)踐方法,感興趣的小伙伴跟著小編一起來看看吧
    2025-01-01
  • spring boot 命令行啟動(dòng)的方式

    spring boot 命令行啟動(dòng)的方式

    這篇文章主要介紹了spring boot 命令行啟動(dòng)的方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Java分析講解序列化與字典功能的序列化

    Java分析講解序列化與字典功能的序列化

    在項(xiàng)目開發(fā)地過程中經(jīng)常會(huì)用到字典存儲(chǔ)某些可配置的值,但相應(yīng)的也會(huì)給開發(fā)帶來復(fù)雜度,比如數(shù)據(jù)庫存儲(chǔ)的值為字典值:0,1,2,3這種類型的值,但是前端頁面卻需要展示為 啟動(dòng)、禁用、刪除 等中文狀態(tài),下面我們來看兩種解決方案
    2022-06-06

最新評(píng)論