当我们开始mybatis入门时,会需要使用到代理开发,博主本人也是在这里耗费了很久的时间才发现这个问题,现在回过头看发现只是一些小问题
<?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="com/example/mapper/UserMapper"> <select id="selectAll" resultType="com.example.demo2.User"> select * from tb_user; </select> </mapper>
结果就是
但其实问题是出在路径上,因为当时我的路径使直接
(下图是复制路径的过程)
就会导致复制出来的路径是带(/)的
我们只需要把/变成点(.)就可以了
<?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="com.example.mapper.UserMapper"> <select id="selectAll" resultType="com.example.demo2.User"> select * from tb_user; </select> </mapper>
结果如下
[User{id=1, name='zhangsan', password='123', gender='男', addr='北京'},
User{id=2, name='lisi', password='456', gender='女', addr='天津'},
User{id=3, name='王五', password='789', gender='男', addr='上海'}]
结果是正确的
在这里再说个题外话
当我们一开始创建代理开发时,我们往往不会把Mapper xml文件和接口文件放一起,因为这对我们后期的拓展业务不太方便,所以我们往往是在resourse文件中创建一个新的mapper文件,它的路径名和接口文件一样
但这里千万千万要注意resourse下创建新文件要用(/)而不能用(.),因为这会导致Mapper文件和接口不在一个路径下
这样就是正确的结果
创建Mapper文件一定要用/!!!