【无标题】Sybase+Mybatis分页查询

分页查询

Sybase不支持limit语法,查询得知SYBASE 12.5.3版本之后,支持了top语法
尝试:

// pageSize:一页的大小;numBefore:前(page-1)的数据条数
select top #{pageSize} * 
from table_name 
where id not in (select top #{numBefore} * 
from table_name
order by id)

出错:

  1. sybase子查询不支持order by,也不支持top
  2. top语法后不能接 #{xxx} 这种入参方式,因为 #{xxx}会默认将变量上加上 ‘’

最终:

select top ${pageNum} * 
from table_name 
order by id

直接取出了前page * pageSize条记录,然后在后端用代码进行分页

因为查到的方法中,有一些是取前page-1页的数据,获得前page-1数据中的最大id,然后再去查询

select top ${pageNum} * 
from table_name 
where id > #{maxId}
order by id

我感觉一次查询拿出前page页的数据没什么太大差别

还有一种方法是:利用临时表存储在指定记录行数前的数据

但是,这种方法我没成功…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Spring Boot项目中使用MyBatis进行分页查询,你可以按照以下步骤进行操作: 1. 首先,确保你的Spring Boot项目中已经引入了MyBatis的相关依赖。可以在你的pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>latest_version</version> </dependency> ``` 2. 创建一个Mapper接口,用于定义分页查询的方法。例如: ```java import org.apache.ibatis.annotations.Mapper; import java.util.List; @Mapper public interface UserMapper { List<User> getUsersByPage(int offset, int limit); } ``` 3. 在对应的Mapper XML文件中编写SQL语句,使用数据库分页功能。例如,使用MySQL的LIMIT语句来实现分页查询: ```xml <select id="getUsersByPage" resultType="User"> SELECT * FROM user LIMIT #{offset}, #{limit} </select> ``` 其中,`offset`表示查询的起始位置,`limit`表示每页返回的记录数。 4. 在Service层或者Controller层中调用Mapper接口的方法进行分页查询。可以使用PageHelper或者手动计算分页参数。 使用PageHelper插件的示例代码如下: ```java import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageInfo; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.List; @Service public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsersByPage(int pageNum, int pageSize) { PageHelper.startPage(pageNum, pageSize); List<User> userList = userMapper.getUsersByPage(); PageInfo<User> pageInfo = new PageInfo<>(userList); return pageInfo.getList(); } } ``` 手动计算分页参数的示例代码如下: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.List; @Service public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsersByPage(int pageNum, int pageSize) { int offset = (pageNum - 1) * pageSize; return userMapper.getUsersByPage(offset, pageSize); } } ``` 这样就可以在Spring Boot项目中使用MyBatis进行分页查询了。 希望对你有所帮助!如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值