Mybatis之低级bug(找了好久)
这里是说我的映射文件出现了错误,但是检查了一遍又一遍,发现sql语句没有错误,命名空间也是没有错误的,而且resultType也没有错误。
<?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="user">
<!-- 插入方法-->
<insert id="insert"> <!--id属性值可以为任意值-->
insert into `user`(uid,uname,`password`)
values(null,#{uname},#{password})
</insert>
<!--删除单个操作-->
<delete id="deleteOne">
/* #{}中的值为实体类对象的值,另一个为数据库中的字段名-->
delete from `user` where uid=#{uid};
</delete>
<!--修改操作-->
<update id="update">
update `user` set uname=#{uname} ,`password`=#{password} where uid=#{uid};
</update>
<!-- 查询操作
id表示唯一标识
resultType 返回值类型,参数值为实体类的全路径名,但是因为这里使用了namespace重命名,所以只要填入重命名即可
-->
<!-- Mapper支持自动映射,会将结果集自动映射给实体类对象-->
<select id="select" resultType="user">
select * from `user` where uid=#{uid};
</select>
<select id="selectOne" resultType="user">
select * from `user` where uname=#{uname};
</select>
<!--登录操作-->
<select id="login" resultType="user">
select * from `user` where uname=#{uname} and `password`=#{password};
</select>
<select id="getUsers" resultType="user">
select * from `user`;
</select>
</mapper>
去网上找了好多的回答,最终还是没有找到想要的答案。而且当我运行其他的映射文件的时候还是显示的User.xml有问题
抱着不解决问题誓不罢休的态度,最终又检查了一遍xml文件,终于在User.xml重找到了问题所在。
!!!!!!!
我将java的注释运用在了xml文件中
而且注意看,当注释运用错误之后,代码片的颜色也会发生变化,从原来的淡黄色变成了IDEA的背景色。
将java的注释修改为xml的注释之后,再次运行项目,成功运行!!!!
泪目~~~~
原来这么低级的错误我也会犯,今天分享出来,给大家避一个坑,希望大家不要犯我这么低级的错误!!!!