LimitSql

public class LimitSql {

    /**
     * 根据数据库类型组装分页sql
     *
     * @param dbName
     *            数据库类型
     * @param column
     *            要查询的列
     * @param tableName
     *            表名
     * @param offset
     * @param limit
     * @return
     */
    public static String getLimitString(String dbName, String column, String tableName, long offset, long limit) {
        String limitString = null;
        if (dbName.toLowerCase().indexOf("mysql") != -1) {
            limitString = getMysqlLimitString(column, tableName, offset, limit);
        }
        if (dbName.toLowerCase().indexOf("oracle") != -1) {
            limitString = getOracleLimitString(column, tableName, offset, limit);
        }

        return limitString;
    }

    private static String getMysqlLimitString(String column, String tableName, long offset, long limit) {
        StringBuffer sb = new StringBuffer();
        sb.append("select ").append(column).append(" from ").append(tableName);
        if (offset > 0) {
            sb.append(" limit ").append(offset).append(',').append(limit);
        } else {
            sb.append(" limit ").append(limit);
        }
        return sb.toString();
    }

    private static String getOracleLimitString(String column, String tableName, long offset, long limit) {
        StringBuffer sb = new StringBuffer();
        if (offset > 0) {
            sb.append("SELECT ").append(column).append(" FROM (")
                    .append(" SELECT A.*, ROWNUM RN FROM ( SELECT * FROM ").append(tableName)
                    .append(" ) A where ROWNUM <= ").append(offset + limit).append(") where RN > ").append(offset);
        } else {
            sb.append("SELECT ").append(column).append(" FROM  ( select * FROM ").append(tableName)
                    .append(" ) WHERE ROWNUM <= ").append(limit);
        }
        return sb.toString();
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值