MyBatis/iBatis - многократно используемые фрагменты sql в отдельном файле карты SQL?
Я хотел бы поместить sql-фрагменты, используемые некоторыми из моих XML файлов XML Map в отдельный файл. На данный момент элементы <sql>
с этими фрагментами находятся в одном из сопоставлений вместе с другими элементами, такими как <select>
, что затрудняет их поиск.
Могу ли я иметь mapper, который определяет только несколько элементов <sql>
и не используется для создания реализации интерфейса? Каким будет правильное пространство имен этого картографа?
Это файл карты SQL с фразами:
<mapper namespace="com.company.project.dao.someDao">
<sql id="whereDate">
WHERE date(`time`) BETWEEN #{startDate} AND #{endDate}
</sql>
<sql id="someOtherSqlFragment">
...
</sql>
<select id="getSomeData"
resultType="SomeClass"
parameterType="DateParam" >
SELECT some_column, another_column
</select>
FROM some_table
<include refid="whereDate"/>
<include refid="otherSqlFragment"/>
</select>
</mapper>
Я хотел бы разделить такие элементы следующим образом:
Первый файл карты Sql:
<mapper namespace="com.company.project.dao.???">
<sql id="whereDate">
WHERE date(`time`) BETWEEN #{startDate} AND #{endDate}
</sql>
<sql id="someOtherSqlFragment">
...
</sql>
</mapper>
Второй файл карты Sql:
<mapper namespace="com.company.project.dao.someDao">
<select id="getSomeData"
resultType="SomeClass"
parameterType="DateParam" >
SELECT some_column, another_column
</select>
FROM some_table
<include refid="whereDate"/>
<include refid="otherSqlFragment"/>
</select>
</mapper>
Ответы
Ответ 1
Это именно то, к чему я работал над проектом. Общие фрагменты были определены в отдельном файле, который был включен в основной файл конфигурации iBATIS.
У нас был файл карты SQL в корневом каталоге с именем Core.ism.xml
, который выглядел следующим образом:
<sqlMap namespace="Core" >
<sql id="fragmentBasicAuditFieldNames">
CreateDate, CreateUser,
UpdateDate, UpdateUser, UpdateCode
</sql>
....
И тогда в наших файлах карты SQL мы могли бы ссылаться на это следующим образом:
<include refid="Core.fragmentBasicAuditFieldNames" />
Надеюсь, я понял, что вы спрашивали правильно!
Ответ 2
Скажем, у вас есть
<mapper namespace="Common">
<sql id="idsIn">
${column} IN
<foreach item="id" collection="ids" separator="," open="(" close=")">
#{id}
</foreach>
</sql>
</mapper>
Чем в другом картографе вы можете использовать его, например:
<mapper namespace="OtherMapper">
<sql id="someSql">
...
<include refid="Common.idsIn">
<property name="column" value="${column}"/>
<!-- OR hardcode: <property name="column" value="id"/> -->
<property name="filterPksTable" value="${filterPksTable}"/>
</include>
...
</sql>
</mapper>
Кроме того, вы можете посмотреть здесь