PageInterceptor.java 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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;
  56. if (sql.toUpperCase().lastIndexOf(" ORDER ") > 0) {
  57. baseSql = sql.substring(0, sql.toUpperCase().lastIndexOf("ORDER"));
  58. }
  59. countSql = "select count(1) from (" + baseSql + ") aliasForPage";
  60. }
  61. PreparedStatement countStatement = connection.prepareStatement(countSql);
  62. ParameterHandler parameterHandler = (ParameterHandler) metaObjet.getValue("delegate.parameterHandler");
  63. parameterHandler.setParameters(countStatement);
  64. ResultSet rs = countStatement.executeQuery();
  65. if (rs.next()) {
  66. page.setTotalNumber(rs.getInt(1));
  67. }
  68. //改造后带分页查询的SQL语句
  69. String pageSql = sql + " limit " + page.getDbIndex() + "," + page.getDbNumber();
  70. if ("SqlServer".equals(getDataBaseType(connection))) {
  71. if (sql.toUpperCase().lastIndexOf(" ORDER ") < 0) {
  72. sql += " ORDER BY 1 ";
  73. }
  74. //改造后带分页查询的SQL语句
  75. pageSql = sql + " offset " + page.getDbIndex() + " row fetch next " + page.getDbNumber() + " row only ";
  76. }
  77. metaObjet.setValue("delegate.boundSql.sql", pageSql);
  78. }
  79. return invocation.proceed();
  80. }
  81. @Override
  82. public Object plugin(Object target) {
  83. return Plugin.wrap(target, this);
  84. }
  85. @Override
  86. public void setProperties(Properties properties) {
  87. // TODO Auto-generated method stub
  88. }
  89. /**
  90. * 判断数据库类型
  91. *
  92. * @return
  93. */
  94. public static String getDataBaseType(Connection connection) {
  95. //通过driverName是否包含关键字判断
  96. try {
  97. if (connection.getMetaData().getDriverName().toUpperCase()
  98. .indexOf("MYSQL") != -1) {
  99. return "MySql";
  100. } else if (connection.getMetaData().getDriverName().toUpperCase()
  101. .indexOf("SQL SERVER") != -1) {
  102. //sqljdbc与sqljdbc4不同,sqlserver中间有空格
  103. return "SqlServer";
  104. }
  105. } catch (SQLException e) {
  106. e.printStackTrace();
  107. }
  108. return "-1";
  109. }
  110. }