类 AnsiDialect

    • 字段详细资料

      • wrapper

        protected Wrapper wrapper
      • namedParameterJdbcTemplate

        protected org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate namedParameterJdbcTemplate
    • 构造器详细资料

      • AnsiDialect

        public AnsiDialect​(org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate namedParameterJdbcTemplate,
                           JdbcProperties jdbcProperties)
    • 方法详细资料

      • getPageJoinSql

        public String getPageJoinSql()
        获得用于SQL字符串拼接的SQL分页字符串

        默认实现MySQL标准,如:

        • LIMIT 0,10(从第一条数据开始,查询10条数据)
        指定者:
        getPageJoinSql 在接口中 Dialect
        返回:
        用于SQL字符串拼接的SQL分页字符串(带具名参数的SQL字符串,非SQL拼接)
      • insertOrUpdate

        public Long insertOrUpdate​(String tableName,
                                   com.alibaba.fastjson.JSONObject paramJson,
                                   String[] conditions,
                                   DbUpdateEnum dBUpdateEnum)
        从接口复制的说明: Dialect
        插入或更新 表中必须存在数据唯一性约束

        更新触发条件:此数据若存在唯一性约束则更新,否则便执行插入数据

        MySQL执行示例:
        INSERT INTO table (param1, param2, ...)
        VALUES
        (:param1, :param2, ...)
        ON DUPLICATE KEY UPDATE
        condition = condition + :condition, ...

        指定者:
        insertOrUpdate 在接口中 Dialect
        参数:
        tableName - 表名
        paramJson - 插入或更新所用到的参数
        conditions - 更新条件(对应paramJson内的key值)
        dBUpdateEnum - 更新类型 DbUpdateEnum
        返回:
        受影响的行数
      • toPage

        public Page toPage​(PageIPO pageIPO)
        从接口复制的说明: Dialect
        转换为经过方言处理的分页查询参数,用于SQL分页查询
        指定者:
        toPage 在接口中 Dialect
        参数:
        pageIPO - 分页查询参数
        返回:
        经过方言处理的分页查询参数
      • page

        public <T> PageVO<T> page​(String tableName,
                                  PageIPO pageIPO,
                                  SortEnum sortEnum,
                                  Class<T> mappedClass)
        从接口复制的说明: Dialect
        单表分页查询

        阿里最优SQL示例:

        SELECT a.* FROM 表1 a, (select id from 表1 where 条件 ORDER BY id LIMIT 100000,20 ) b where a.id=b.id

        指定者:
        page 在接口中 Dialect
        类型参数:
        T - 泛型
        参数:
        tableName - 表名
        pageIPO - 分页查询参数 PageIPO,所有的条件参数,都将以等于的形式进行SQL拼接
        sortEnum - 排序方式 SortEnum
        mappedClass - 映射类
        返回:
        count(总数),data(分页列表数据)
      • pageWhere

        public <T> PageVO<T> pageWhere​(String tableName,
                                       String whereSql,
                                       PageIPO pageIPO,
                                       Class<T> mappedClass)
        从接口复制的说明: Dialect
        单表分页查询

        阿里最优SQL示例:

        SELECT a.* FROM 表1 a, (select id from 表1 where 条件 LIMIT 100000,20 ) b where a.id=b.id

        指定者:
        pageWhere 在接口中 Dialect
        类型参数:
        T - 泛型
        参数:
        tableName - 表名
        whereSql - 自定义WHERE语句,若此参数为空,那么所有的条件参数,都将以等于的形式进行SQL拼接。
        SQL示例: WHERE 条件
        pageIPO - 分页查询参数 PageIPO
        mappedClass - 映射类
        返回:
        count(总数),data(分页列表数据)
      • pageSql

        public <T> PageVO<T> pageSql​(String querySql,
                                     PageIPO pageIPO,
                                     Class<T> mappedClass)
        从接口复制的说明: Dialect
        复杂SQL分页查询

        阿里最优查询SQL示例:

        SELECT a.* FROM 表1 a, (select id from 表1 where 条件 LIMIT :page, :limit) b where a.id=b.id

        指定者:
        pageSql 在接口中 Dialect
        类型参数:
        T - 泛型
        参数:
        querySql - 用于查询数据的sql语句
        pageIPO - 分页查询参数 PageIPO
        mappedClass - 映射类
        返回:
        count(总数),data(分页列表数据)
      • pageSql

        public <T> PageVO<T> pageSql​(@Nullable
                                     String countSql,
                                     String querySql,
                                     PageIPO pageIPO,
                                     Class<T> mappedClass)
        从接口复制的说明: Dialect
        复杂SQL分页查询

        统计SQL示例:

        SELECT count(*) count FROM 表1 a, (select id from 表1 where 条件) b where a.id=b.id

        阿里最优查询SQL示例:

        SELECT a.* FROM 表1 a, (select id from 表1 where 条件 LIMIT :page, :limit) b where a.id=b.id

        指定者:
        pageSql 在接口中 Dialect
        参数:
        countSql - 用于统计总数的sql语句 (注意:count(*)必须拥有count别名) 同时countSql可以为null表示不统计 可选参数
        querySql - 用于查询数据的sql语句
        pageIPO - 分页查询参数 PageIPO
        mappedClass - 映射类
        返回:
        count(总数),data(分页列表数据)