最近做项目的时候遇到一个问题,使用mybatis作为项目的持久层,举一个简单的例子:
<select id="getAccountByName" parameterType="String" resultType="Account">
select
accountname as accountName,
accountpswd as accountPassword,
createtime as createTime
from
account
where
accountname = #{accountName }
</select>
这是在mapper文件中的一段配置,很简单就是通过accountName获取account的相应信息。
不知道你又没有看出这段配置中的错误,反正我被这个问题折磨了一天!
#{}是mybatis中的一种占位符,它会将传入的数据预编译后去除关键字等后放到相应的位置,不过使用占位符的时候我们千万不能留有空格!!
#{accountName(这里有一个空格)},正确的写法是: #{accountName} ,将所有位置占满不留一个空格!!!!
其实道理很简单,mybatis的映射原理就是Map,如果我们在一个map中存入一个值:map.put("key ","value"),在通过map.get("key");取出来的为null。万恶的空格呀。

8440

被折叠的 条评论
为什么被折叠?



