Mybatis的Xml映射文件中,不同Xml映射文件,id是否可以重复详解

Mybatis的Xml映射文件中,不同Xml映射文件,id是否可以重复?

不同的Xml映射文件,如果配置了namespace,那么id可以重复;如果没有配置namespace,那么id不能重复.

(不管是什么id,即使不是同种类型,譬如说查询的id跟更新的id不一样也不行.反正就是所有id都不能重复,因为id就是一个标识)

个人批注:问题的意思应该是在不使用mapper接口编程的时候,如果在测试的时候写的是namespace+id,那么不同Xml映射文件id可以重复.如果没有配置namespace,也就是说在测试的时候没有写namespace,直接写id,那么不同映射文件的id是不可以重复的.

详解:

1.首先,一个mapper.xml文件中只能有一个<mapper></mapper>,必须配置namespace,不管对不对,不配置namespace或者namespace为空,都会直接报错!

不同xml映射文件namespace的值不能一样.有一样的会直接报错!

2.如果使用mapper接口编程,一定要配置namespace,指向相应的mapper接口文件.这时候不同Xml映射文件id是可以重复的.当然同一个xml映射文件中的id是肯定不能重复的.

3.没有配置namespace是指随便配置一个namespace,随便配置什么都行,(经过测试,namespace不能为空,会直接报错,可以随便写,但是不能不写.).

4如果在测试的时候写的是namespace+id,那么不同Xml映射文件id可以重复.如果没有配置namespace,也就是说在测试的时候没有写namespace,直接写id,那么不同映射文件的id是不可以重复的.

接下来是一个没有配置namespace(也就是说在测试的时候,不写namespace,直接写id),id重复会报错的例子.

(EmployeeMapper.xml跟EmployeeMapper2.xml中的namespace是不一样的,但是里面的id是一样的.)

EmployeeMapper.xml

<?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="test">

    <select id="selectAllEmployee" resultType="Employee">
      /*查询全部*/
        select id,name,age,birthday,salary from t_employee
    </select>
</mapper>

EmployeeMapper2.xml

<?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="test2">

    <select id="selectAllEmployee" resultType="Employee">
      /*查询全部*/
        select id,name,age,birthday,salary from t_employee
    </select>
</mapper>

MabatisTest.java

package com.xiongluoluo.test;

import com.xiongluoluo.bean.Employee;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

/**
 * Created by Administrator on 2019/12/21 0021.
 */
public class MybatisTest {
    @Test
    public void testSelectAllEmployee(){
        String resource = "mybatis-config.xml";
        try {
            InputStream is = Resources.getResourceAsStream(resource);
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
            SqlSession sqlSession = sqlSessionFactory.openSession();
            List<Employee> list = sqlSession.selectList("test.selectAllEmployee");

           //如果这里用的是namespace+id那么就不会报错.

           //如果这里直接写的id那么就会报错.因为在不同的映射文件里有相同的id.


            for(Employee employee : list){
                System.out.println(employee);
            }

        } catch (IOException e) {
            e.printStackTrace();
        }

    }
}

 

发布了100 篇原创文章 · 获赞 7 · 访问量 7579

猜你喜欢

转载自blog.csdn.net/qq_40245464/article/details/103651087