数据库分页sql

String p_dbmsType = "oracle";// 数据库类型
		String pageSql = "";
		try {
			p_dbmsType = Platform.getPlatform().getDbTpye();
		} catch (Exception e) {

		} finally {
			// 无法读取默认为oracle数据库
			if (p_dbmsType == null || "".equals(p_dbmsType)) {
				p_dbmsType = "oracle";
			}
		}

		if (p_dbmsType.toUpperCase().equals("ORACLE")) {
			int rowCount = start + limit;
			// 组装分页sql
			StringBuilder sb = new StringBuilder(
					"select * from ( select row_.*, rownum rownum_ from( ");
			sb.append(sql);
			sb.append(" ) row_ where rownum <=").append(rowCount)
					.append(") where rownum_ > ").append(start);
			pageSql = sb.toString();
		}// oralce
		else if (p_dbmsType.toUpperCase().equals("SQLSERVER")) {
			/** 替换sql为可分组方式 */
			int rowCount = start + limit;
			sql = sql.replaceFirst("(?i)select", "select top " + rowCount
					+ " tempColumn=0,");

			/** 编辑为分页sql */
			StringBuilder sb = new StringBuilder();
			sb.append(" select * from ( ")
					.append(" select row_number()over(order by tempColumn)tempRowNumber,* from ( ")
					.append(sql).append(" )t ").append(" )tt ")
					.append(" where tempRowNumber>").append(start);
			pageSql = sb.toString();
		}// sqlserver
		else if (p_dbmsType.toUpperCase().equals("MYSQL")) {
			StringBuilder sb = new StringBuilder();
			sb.append(sql);
			sb.append(" LIMIT ").append(start).append(",").append(limit);
			pageSql = sb.toString();
		}
		return pageSql;
	}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值