Module bus.pager

Class Db2

All Implemented Interfaces:
Dialect

public class Db2 extends AbstractPaging
Database dialect for DB2. This class provides DB2-specific implementations for pagination SQL generation and parameter processing.
Since:
Java 17+
Author:
Kimi Liu
  • Constructor Details

    • Db2

      public Db2()
  • Method Details

    • processPageParameter

      public Object processPageParameter(org.apache.ibatis.mapping.MappedStatement ms, Map<String,Object> paramMap, Page page, org.apache.ibatis.mapping.BoundSql boundSql, org.apache.ibatis.cache.CacheKey pageKey)
      Processes the pagination parameters for DB2. It adds PAGEPARAMETER_FIRST and PAGEPARAMETER_SECOND to the parameter map and updates the CacheKey.
      Specified by:
      processPageParameter in class AbstractPaging
      Parameters:
      ms - the MappedStatement object
      paramMap - a map containing the query parameters
      page - the Page object containing pagination details
      boundSql - the BoundSql object for the query
      pageKey - the CacheKey for the paginated query
      Returns:
      the processed parameter map
    • getPageSql

      public String getPageSql(String sql, Page page, org.apache.ibatis.cache.CacheKey pageKey)
      Generates the DB2-specific pagination SQL. It wraps the original SQL with a subquery that uses ROWNUMBER() OVER() to achieve pagination.
      Specified by:
      getPageSql in class AbstractPaging
      Parameters:
      sql - the original SQL string
      page - the Page object containing pagination details
      pageKey - the CacheKey for the paginated query
      Returns:
      the DB2-specific paginated SQL string