我在我的应用中使用了mybatis。我在我的select元素中使用了bind标签。这是我的映射器代码:
<?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="myapp.model.MyDAO">
<select id="mySelect" parameterType="myapp.model.MyParameterBean" resultType="hashmap">
<bind name="SL" value="_parameter.getSelectList()" />
<bind name="TNS" value="_parameter.getTableNameSuffix()" />
SELECT NAME
#{SL}
FROM MYTABLE_#{TNS}
</select>
</mapper>当我尝试编译我的应用程序时,我得到一个SAXParseException。详细的错误消息为:
无法分析映射资源:'file C:\myapp\model\myMapper.xml';嵌套异常为org.apache.ibatis.builder.BuilderException:创建文档实例时出错。原因: org.xml.sax.SAXParseException:必须声明元素类型"bind“。你对这个行为有什么想法吗?
我使用了spring-mvc。对于spring-mybatis集成,我包含了mybatis-spring-1.1.0.jar。
大家好!
发布于 2014-04-14 18:26:25
在我的例子中,完全是dynamic.select列表或表名后缀取决于参数。
<?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="myapp.model.MyDAO">
<select id="mySelect" parameterType="myapp.model.MyParameterBean" resultType="hashmap">
<bind name="SL" value="_parameter.getSelectList()" />
<bind name="TNS" value="_parameter.getTableNameSuffix()" />
SELECT NAME
#{SL}
FROM MYTABLE_#{TNS}
</select>
</mapper>发布于 2014-04-14 18:06:44
<sql>和<include>标记示例
<sql id="columns">
SURNAME,ADDRESS
</sql>
<select id="mySelect" resultType="hashmap">
SELECT NAME,
<include refid="columns">
FROM MYTABLE
</select>https://stackoverflow.com/questions/23056777
复制相似问题