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

Mybatis的mapper標(biāo)簽 namespace屬性用法說明

 更新時(shí)間:2021年09月30日 10:23:49   作者:hugh Lee  
這篇文章主要介紹了Mybatis的mapper標(biāo)簽 namespace屬性用法說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Mybatis mapper標(biāo)簽namespace屬性說明

在mybatis中,映射文件中的namespace是用于綁定Dao接口的,即面向接口編程。

當(dāng)你的namespace綁定接口后,你可以不用寫接口實(shí)現(xiàn)類,mybatis會(huì)通過該綁定自動(dòng)幫你找到對(duì)應(yīng)要執(zhí)行的SQL語句,如下:

假設(shè)定義了IArticeDAO接口

public interface IArticleDAO
{
   List<Article> selectAllArticle();
}

對(duì)于映射文件如下:

<mapper namespace="IArticleDAO">
    <select id="selectAllArticle" resultType="article">
            SELECT t.* FROM T_article t WHERE t.flag = '1' ORDER BY t.createtime DESC
     </select>

請(qǐng)注意接口中的方法與映射文件中的SQL語句的ID一一對(duì)應(yīng) 。

則在代碼中可以直接使用IArticeDAO面向接口編程而不需要再編寫實(shí)現(xiàn)類。

MyBatis的命名空間(我們以下圖的文件結(jié)構(gòu)來說明)

MyBatis的命名空間說的是POJO的XXx.xml文件中的<mapper namespace=”” />,主要是跟三個(gè)地方有關(guān)系,

  • 第一個(gè)是Configuration.xml的mappers屬性
  • 第二個(gè)是POJO的mapper接口如EmployeeMapper的類路徑
  • 第三個(gè)是DAO程序中的session.getConfiguration().addMapper(EmployeeMapper.class)

下面我來說一下他們?nèi)齻€(gè)之間的關(guān)系,我們

1)當(dāng)只使用XML(不使用Anotation)的來配置mapper接口時(shí)

就是我們把sql配置在EmployeeMap.xml中時(shí),若我們把namespace指明namespace設(shè)置為mapper接口的路徑,即<mapper namespace="com.wildrain.mapper.EmployeeMapper">時(shí),這樣我們?cè)诔绦蛑惺褂肕yBatis來進(jìn)行CRUD時(shí), session.getConfiguration().addMapper(EmployeeMapper.class)這段代碼可以不用寫。我們來具體看一下這個(gè)三個(gè)地方的代碼形式。

Configuration.xml的mappers
<typeAliases>
       <typeAlias alias="Employee" type="com.wildrain.domain.Employee" />
    </typeAliases>
Namespace
<mapper namespace="com.wildrain.mapper.EmployeeMapper">

程序代碼:

    @Test
    public void testGetAllEmployees(){
       SqlSessionFactory sqlSessionFactory =  MyBatisUtil.getSessionFactory();
       SqlSession session = sqlSessionFactory.openSession();
       try {
           EmployeeMapper mapper = session.getMapper(EmployeeMapper.class);
           List<Employee> ems = mapper.getAllEmployees();
           for(Employee e:ems){
              System.out.println(e);
           }
       } finally {
           session.close();
       }
}

若我們?cè)趀mployee.xml中的namespace是任意取的名字,而不是EmployeeMapper.java的類路徑名,那么當(dāng)我們?cè)谶M(jìn)行測(cè)試時(shí),必須要添加一行代碼session.getConfiguration().addMapper(EmployeeMapper.class)進(jìn)行注冊(cè),下代碼如下:

@Test
    public void testGetAllEmployees(){
       SqlSessionFactory sqlSessionFactory =  MyBatisUtil.getSessionFactory();
       SqlSession session = sqlSessionFactory.openSession();
       session.getConfiguration().addMapper(EmployeeMapper.class);
       try {
           EmployeeMapper mapper = session.getMapper(EmployeeMapper.class);
           List<Employee> ems = mapper.getAllEmployees();
           for(Employee e:ems){
              System.out.println(e);
           }
       } finally {
           session.close();
       }
}

2)當(dāng)使用注解時(shí)

為了減少配制xml的工作量,可以把Employee.xml省略,而把相應(yīng)配制通過注解的形式寫到EmployeeMapper.java的文件中,如下所示

final String getAllEmployees = "SELECT E.id, name, type, salay, time "+
       "FROM employee E "+
       "left join register r on r.eid = E.id "+
    "left join time t on t.eid = E.id";
@Select(getAllEmployees)
    @TypeDiscriminator(column = "type",
           cases={   
           @Case(value="1",type=RegisterEmployee.class,results={
              @Result(property="salay")
           }) ,
           @Case(value="2",type=TimeEmployee.class,results={
              @Result(property="time")
           })
})

這樣Configuration.xml中就不需要設(shè)置<mappers/>了,此時(shí)在測(cè)試程序時(shí)就必須加一行

session.getConfiguration().addMapper(EmployeeMapper.class);

的代碼進(jìn)行注冊(cè),這樣在每一次CRUD時(shí)都需要添加一行這樣的代碼。

還不如在建立一個(gè)空的Employee.xml文件,然后像上面一樣設(shè)置好namespace,從而不用輸入那一行代碼。

上面的說明針對(duì)的是,僅針對(duì)使用mybats動(dòng)態(tài)代理時(shí)的情況。寫得比較亂,以后有時(shí)間再改。

Mybatis中namespace的作用

在mybatis中,映射文件中的namespace是用于綁定Dao接口的,即面向接口編程。

當(dāng)你的namespace綁定接口后,你可以不用寫接口實(shí)現(xiàn)類,mybatis會(huì)通過該綁定自動(dòng) 幫你找到對(duì)應(yīng)要執(zhí)行的SQL語句

ItemsCustomMapperxml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="cn.itcast.ssm.mapper.ItemsMapperCustom" >
   <!-- 定義商品查詢的sql片段,就是商品查詢條件 -->
   <sql id="query_items_where">
    <!-- 使用動(dòng)態(tài)sql,通過if判斷,滿足條件進(jìn)行sql拼接 -->
    <!-- 商品查詢條件通過ItemsQueryVo包裝對(duì)象 中itemsCustom屬性傳遞 -->
        <if test="itemsCustom!=null">
            <if test="itemsCustom.name!=null and itemsCustom.name!=''">
                items.name LIKE '%${itemsCustom.name}%'
            </if>
        </if>
   </sql>
    <!-- 商品列表查詢 -->
    <!-- parameterType傳入包裝對(duì)象(包裝了查詢條件)
        resultType建議使用擴(kuò)展對(duì)象
     -->
    <select id="findItemsList" parameterType="cn.itcast.ssm.po.ItemsQueryVo"
         resultType="cn.itcast.ssm.po.ItemsCustom">
        SELECT items.* FROM items  
        <where>
            <include refid="query_items_where"></include>
        </where>
    </select>
</mapper>

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

相關(guān)文章

最新評(píng)論