PageInterceptor.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package com.izouma.awesomeadmin.interceptor;
  2. import java.sql.Connection;
  3. import java.sql.PreparedStatement;
  4. import java.sql.ResultSet;
  5. import java.sql.SQLException;
  6. import java.util.Map;
  7. import java.util.Properties;
  8. import org.apache.ibatis.executor.parameter.ParameterHandler;
  9. import org.apache.ibatis.executor.statement.StatementHandler;
  10. import org.apache.ibatis.mapping.BoundSql;
  11. import org.apache.ibatis.mapping.MappedStatement;
  12. import org.apache.ibatis.plugin.Interceptor;
  13. import org.apache.ibatis.plugin.Intercepts;
  14. import org.apache.ibatis.plugin.Invocation;
  15. import org.apache.ibatis.plugin.Plugin;
  16. import org.apache.ibatis.plugin.Signature;
  17. import org.apache.ibatis.reflection.DefaultReflectorFactory;
  18. import org.apache.ibatis.reflection.MetaObject;
  19. import org.apache.ibatis.reflection.SystemMetaObject;
  20. import com.izouma.awesomeadmin.constant.AppConstant;
  21. import com.izouma.awesomeadmin.dto.Page;
  22. /**
  23. * <p>分页拦截器 </p>
  24. *
  25. * @author 姓名 <br />
  26. * 更新履历 <br />
  27. * 日期 : 姓名: 更新内容<br />
  28. * @version 1.0
  29. */
  30. @Intercepts({@Signature(type = StatementHandler.class, method = "prepare", args = {Connection.class})})
  31. public class PageInterceptor implements Interceptor {
  32. @Override
  33. public Object intercept(Invocation invocation) throws Throwable {
  34. StatementHandler statementHandler = (StatementHandler) invocation.getTarget();
  35. MetaObject metaObjet = MetaObject.forObject(statementHandler, SystemMetaObject.DEFAULT_OBJECT_FACTORY,
  36. SystemMetaObject.DEFAULT_OBJECT_WRAPPER_FACTORY, new DefaultReflectorFactory());
  37. MappedStatement mappedStatement = (MappedStatement) metaObjet.getValue("delegate.mappedStatement");
  38. //配置文件中SQL语句的ID
  39. String id = mappedStatement.getId();
  40. //检查以ByPage结尾的id
  41. if (id.matches(".+ByPage$")) {
  42. BoundSql bounSql = statementHandler.getBoundSql();
  43. //原始的SQL语句
  44. String sql = bounSql.getSql();
  45. Connection connection = (Connection) invocation.getArgs()[0];
  46. //默认mysql数据库
  47. //查询总条数的SQL语句
  48. String countSql = "select count(1) from (" + sql + ") aliasForPage";
  49. Page page = new Page();
  50. Map<?, ?> parameter = (Map<?, ?>) bounSql.getParameterObject();
  51. if (parameter != null) {
  52. page = (Page) parameter.get(AppConstant.PAGE);
  53. }
  54. if ("SqlServer".equals(getDataBaseType(connection))) {
  55. String baseSql = sql.substring(0, sql.toUpperCase().lastIndexOf("ORDER"));
  56. countSql = "select count(1) from (" + baseSql + ") aliasForPage";
  57. }
  58. PreparedStatement countStatement = connection.prepareStatement(countSql);
  59. ParameterHandler parameterHandler = (ParameterHandler) metaObjet.getValue("delegate.parameterHandler");
  60. parameterHandler.setParameters(countStatement);
  61. ResultSet rs = countStatement.executeQuery();
  62. if (rs.next()) {
  63. page.setTotalNumber(rs.getInt(1));
  64. }
  65. //改造后带分页查询的SQL语句
  66. String pageSql = sql + " limit " + page.getDbIndex() + "," + page.getDbNumber();
  67. if ("SqlServer".equals(getDataBaseType(connection))) {
  68. //改造后带分页查询的SQL语句
  69. pageSql = sql + " offset " + page.getDbIndex() + " row fetch next " + page.getDbNumber() + " row only ";
  70. }
  71. metaObjet.setValue("delegate.boundSql.sql", pageSql);
  72. }
  73. return invocation.proceed();
  74. }
  75. @Override
  76. public Object plugin(Object target) {
  77. return Plugin.wrap(target, this);
  78. }
  79. @Override
  80. public void setProperties(Properties properties) {
  81. // TODO Auto-generated method stub
  82. }
  83. /**
  84. * 判断数据库类型
  85. *
  86. * @return
  87. */
  88. public static String getDataBaseType(Connection connection) {
  89. //通过driverName是否包含关键字判断
  90. try {
  91. if (connection.getMetaData().getDriverName().toUpperCase()
  92. .indexOf("MYSQL") != -1) {
  93. return "MySql";
  94. } else if (connection.getMetaData().getDriverName().toUpperCase()
  95. .indexOf("SQL SERVER") != -1) {
  96. //sqljdbc与sqljdbc4不同,sqlserver中间有空格
  97. return "SqlServer";
  98. }
  99. } catch (SQLException e) {
  100. e.printStackTrace();
  101. }
  102. return "-1";
  103. }
  104. }