ibatis配置limit

<select id="table" > 
select * from table 
<dynamic prepend = "limit " > 
<isNotEqual property="num" compareValue="0" > 
0,#num# 
</isNotEqual> 

</dynamic> 

</select>



<dynamic prepend="limit"> 
<isNotNull property="rowStart"> 
<isNotNull property="pageSize"> 
#rowStart#, #pageSize# 
</isNotNull> 
</isNotNull> 
</dynamic> 



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 MyBatis 中,可以使用 `<databaseIdProvider>` 标签来配置不同的数据库标识,以便在 SQL 映射文件中使用不同的 SQL 语句。下面是一个配置类的示例: ```java import javax.sql.DataSource; import org.apache.ibatis.mapping.DatabaseIdProvider; import org.apache.ibatis.mapping.VendorDatabaseIdProvider; import org.mybatis.spring.SqlSessionFactoryBean; import org.springframework.context.annotation.Bean; @Configuration public class MyBatisConfig { @Bean public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource, DatabaseIdProvider databaseIdProvider) throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource); sessionFactory.setDatabaseIdProvider(databaseIdProvider); return sessionFactory; } @Bean public DatabaseIdProvider databaseIdProvider() { VendorDatabaseIdProvider databaseIdProvider = new VendorDatabaseIdProvider(); Properties properties = new Properties(); properties.setProperty("Oracle", "oracle"); properties.setProperty("MySQL", "mysql"); properties.setProperty("PostgreSQL", "postgresql"); databaseIdProvider.setProperties(properties); return databaseIdProvider; } } ``` 在这个配置类中,我们定义了一个 `SqlSessionFactoryBean` 的 bean,其中包含了一个 `DatabaseIdProvider` 的 bean。`DatabaseIdProvider` 是用来识别数据库厂商标识的接口,`VendorDatabaseIdProvider` 是一个实现了该接口的类,可以通过设置 `Properties` 对象中的键值对来识别不同的数据库厂商。在上面的示例中,我们设置了 Oracle、MySQL 和 PostgreSQL 三种数据库的标识。这样,在 SQL 映射文件中,就可以使用 `<if>` 标签来判断当前使用的数据库类型,然后执行相应的 SQL 语句。例如: ```xml <select id="getUserList" resultType="User"> <if test="_databaseId == 'oracle'"> SELECT * FROM user WHERE ROWNUM <= #{limit} </if> <if test="_databaseId == 'mysql'"> SELECT * FROM user LIMIT #{limit} </if> <if test="_databaseId == 'postgresql'"> SELECT * FROM user LIMIT #{limit} OFFSET #{offset} </if> </select> ``` 在上面的示例中,使用了 `_databaseId` 变量来获取当前数据源的标识。这个变量的值就是我们在 `Properties` 对象中设置的键值对中的值。根据这个值,就可以执行相应的 SQL 语句。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值