mybatis学习记录(三)-----关于SQL Mapper的namespace

关于SQL Mapper的namespace

视频总结笔记:

在SQL Mapper配置文件中<mapper>标签的namespace属性可以翻译为命名空间,这个命名空间主要是为了防止SQL id 冲突的。

创建CarMapper2.xml文件,代码如下:

CarMapper2.xml:

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="car2">
    <select id="selectCarAll" resultType="com.powernode.mybatis.pojo.Car">
        select
            id, car_num as carNum, brand, guide_price as guidePrice, produce_time as produceTime, car_type as carType
        from
            t_car
    </select>
</mapper>

不难看出,CarMapper.xml和CarMapper2.xml文件中都有 id="selectCarAll"

将CarMapper2.xml配置到mybatis-config.xml文件中。

mybatis-config.xml:

XML 复制代码
<mappers>
  <mapper resource="CarMapper.xml"/>
  <mapper resource="CarMapper2.xml"/>
</mappers>

编写Java代码如下:

CarMapperTest.testNamespace:

java 复制代码
@Test
public void testNamespace(){
    // 获取SqlSession对象
    SqlSession sqlSession = SqlSessionUtil.openSession();
    // 执行SQL语句
    List<Object> cars = sqlSession.selectList("selectCarAll");
    // 输出结果
    cars.forEach(car -> System.out.println(car));
}

运行结果如下:

异常信息:

sql 复制代码
org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: java.lang.IllegalArgumentException: 
  selectCarAll is ambiguous in Mapped Statements collection (try using the full name including the namespace, or rename one of the entries) 
  【翻译】selectCarAll在Mapped Statements集合中不明确(请尝试使用包含名称空间的全名,或重命名其中一个条目)
  【大致意思是】selectCarAll重名了,你要么在selectCarAll前添加一个名称空间,要有你改个其它名字。

ava代码修改如下:

CarMapperTest.testNamespace:

java 复制代码
@Test
public void testNamespace(){
    // 获取SqlSession对象
    SqlSession sqlSession = SqlSessionUtil.openSession();
    // 执行SQL语句
    //List<Object> cars = sqlSession.selectList("car.selectCarAll");
    List<Object> cars = sqlSession.selectList("car2.selectCarAll");
    // 输出结果
    cars.forEach(car -> System.out.println(car));
}

运行结果如下:

相关推荐
啥也不会的菜鸟·2 小时前
Redis7——进阶篇(八)
redis·学习·缓存
大苏打seven2 小时前
Java学习笔记(多线程):ReentrantLock 源码分析
java·笔记·学习
张张张3123 小时前
4.8学习总结 贪心算法+Stream流
java·学习
鑫—萍4 小时前
数据结构与算法——链表OJ题详解(1)
c语言·开发语言·数据结构·c++·学习·算法·链表
傍晚冰川4 小时前
【已完结STM32】--自学江协科技笔记汇总
笔记·科技·stm32·嵌入式硬件·学习
RainbowSea4 小时前
7. MySQL 当中的 InnoDB 数据存储结构(详解)
java·sql·mysql
cwtlw4 小时前
PhotoShop学习06
笔记·学习·photoshop
烧瓶里的西瓜皮4 小时前
Go语言从零构建SQL数据库(6) - sql解析器(番外)- *号的处理
数据库·sql·golang
qq_589568105 小时前
java学习笔记13——IO流
java·笔记·学习·intellij-idea
快乐的木子李5 小时前
Java spring mybatis面试题(200道),八股文
java·开发语言·spring·mybatis