`

ibatis <sql>和<include>

 
阅读更多

<sql>和<include>,前者用来创建一个文本片段,这些片段可以组合起来创建完整的SQL语句;后者很显然就是包含的意思

 

<sql id="select-user">  

    select * from users  

</sql>  

<sql id="select-count">  

    select count(*) as value from users  

</sql>  

<sql id="where-age-over-value">  

    <![CDATA[ 

        where age > #value:INT# 

    ]]>  

</sql>  

<select id="getUserAgeOver" resultClass="hashmap">  

    <include refid="select-user" />  

    <include refid="where-age-over-value" />  

</select>  

<select id="getUserCountAgeOver" resultClass="int">  

    <include refid="select-count" />  

    <include refid="where-age-over-value" />  

</select> 

分享到:
评论

相关推荐

    ibatis多表查询过程

    iBatis的动态SQL功能非常强大,可以通过`&lt;if&gt;`、`&lt;choose&gt;`、`&lt;when&gt;`、`&lt;otherwise&gt;`、`&lt;where&gt;`、`&lt;set&gt;`等标签编写条件语句,根据传入参数动态生成SQL。 ### 8. 使用`&lt;foreach&gt;`标签 `&lt;foreach&gt;`标签用于遍历...

    ibatis动态注入

    为了提高代码复用性,iBATIS还支持将动态SQL片段定义为独立的`&lt;sql&gt;`标签,如: ```xml &lt;sql id="queryCondition"&gt; &lt;dynamic prepend="WHERE"&gt; &lt;isGreaterThan prepend="and" property="id" compareValue="0"&gt; ...

    ibatis资料(官方文档)

    在SQL映射文件中,使用`&lt;parameterMap&gt;`和`&lt;parameter&gt;`元素来定义参数,它可以是简单的类型(如int、String)或复杂的Java对象。 **4. 结果映射** `&lt;resultMap&gt;`元素定义了如何将数据库查询结果映射到Java对象。...

    ibatis技术总结

    12. **&lt;include&gt;组合语句**:用于包含另一个SQL片段,实现SQL语句的组合。 13. **&lt;selectKey&gt;**:定义主键生成策略,常用于自动填充主键字段。 这些标签共同构成了iBatis的SQL映射规则体系,确保了框架能够正确...

    ibatis学习资料

    - **&lt;include&gt;组合语句**:组合多个SQL语句片段。 #### SQL参数详解 - **#符号占位符**:表示预编译参数,提高安全性,防止SQL注入。 - **$符号占位符**:表示字符串拼接,使用时需注意SQL注入风险。 #### 动态...

    mybatis文档

    `&lt;sql&gt;` 和 `&lt;include&gt;` 标签的应用 - **使用场景**:通过 `&lt;sql&gt;` 标签定义可重用的 SQL 片段,使用 `&lt;include&gt;` 引用这些片段,以减少重复编写相同的 SQL 语句。 #### 6. 添加数据时返回主键值 - **解决方案**...

    mybatis自定义分页标签

    &lt;name&gt;sqlId&lt;/name&gt; &lt;required&gt;true&lt;/required&gt; &lt;rtexprvalue&gt;true&lt;/rtexprvalue&gt; &lt;/attribute&gt; &lt;attribute&gt; &lt;name&gt;pageSize&lt;/name&gt; &lt;required&gt;false&lt;/required&gt; &lt;rtexprvalue&gt;true&lt;/rtexprvalue&gt; &lt;/...

    ibatis 动态代理dtd

    此示例展示了如何使用`&lt;dynamic&gt;`元素结合`&lt;isNotNull&gt;`和`&lt;isNotEqual&gt;`元素来动态生成SET子句,只更新非空且满足特定条件的字段。 通过上述分析可以看出,ibatis的动态SQL功能非常强大,能够极大地提高开发效率并...

    利用Mybatis的动态SQL实现物理分页.pdf

    &lt;include refid="Head"&gt;&lt;/include&gt; &lt;include refid="Tail"&gt;&lt;/include&gt; &lt;/select&gt; ``` 在这个配置中,`&lt;if&gt;`标签用于根据传入参数动态添加SQL片段。当`start`和`end`参数存在时,Mybatis会生成包含`LIMIT`子句的...

    [struts2、spring、ibatis]框架开发开发

    &lt;include file="struts-default.xml"/&gt; &lt;package name="struts2" extends="struts-default"&gt; &lt;default-interceptor-ref name="paramsPrepareParamsStack"/&gt; &lt;action name="login" class="LoginAction"&gt; &lt;result...

    ibatis 指导书 PDF

    6. **`&lt;sqlMap&gt;` 元素**:引入 SQL 映射文件,定义具体的 SQL 查询和映射规则。 #### 五、SQL Map XML 映射文件详解 **映射文件主要组成部分:** - **MappedStatements**:描述 SQL 语句及结果映射规则。 - **...

    SpringBoot 整合Mybatis 创建临时表

    SpringBoot简化了Spring的配置,提供了快速构建应用程序的能力,而Mybatis则是一个轻量级的持久层框架,专注于SQL映射和实体对象之间的交互。当我们需要处理一些临时性的数据操作时,可能会涉及到创建临时表。下面...

    ibatis环境搭建教程

    - **&lt;include&gt;**:用于引用其他配置文件,有助于保持配置文件的简洁性。 - **&lt;selectKey&gt;`**:用于生成主键,在某些数据库中可能需要在插入记录前先获取自增主键值。 - **&lt;insert&gt;`**:定义插入操作,可以与`...

    Ibatis.net 分页

    &lt;include refid="PagingSql"/&gt; &lt;/procedure&gt; &lt;sql id="PagingSql"&gt; ORDER BY UserId LIMIT #start#, #limit# &lt;/sql&gt; &lt;/sqlMap&gt; ``` 这里的`PagingParams`类需要包含`Start`(起始位置,即(页码-1)* PageSize...

    解决IBatis缓存动态字段问题

    1. **检查 SQL 语句**:首先确认所有涉及到动态表名和动态字段名的 `&lt;select&gt;` 标签中是否都已经正确地设置了 `remapResults="true"` 属性。 2. **代码审查**:对于所有涉及到动态表名和字段名的操作,需要仔细检查...

    MyBatis 入门实例 很详细很全面的中文文档

    &lt;include resource="com/example/UserMapper.xml"/&gt; &lt;/mapper&gt; ``` **7. 使用 SqlSessionFactory 和 SqlSession** MyBatis 提供了 `SqlSessionFactory` 和 `SqlSession` 两个关键对象。`SqlSessionFactory` 是工厂...

    ibatis的教程

    例如,在一个insert操作中,可以使用&lt;insert&gt;标签来定义插入语句,并通过&lt;Parameter&gt;和&lt;value&gt;标签来绑定参数。当需要返回数据库自动生成的主键值时,可以使用&lt;selectKey&gt;标签来获取,这在SQL Server中常用于获取...

    ibatis分页技术

    3. **整合分页逻辑到查询中**:在具体的查询语句中,通过`&lt;include&gt;`标签引用`page_begin`和`page_end`,将分页逻辑嵌入到主查询中。同时,还可以结合其他查询条件,如`find_xx`、`from_xx`、`where_xx`和`order_by`...

Global site tag (gtag.js) - Google Analytics