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