Greenplum【SQL 02】ROW_NUMBER编号函数使用方法举例

简介: Greenplum【SQL 02】ROW_NUMBER编号函数使用方法举例

1. 问题说明

-- 类似这种 SQL
SELECT * FROM tableName WHERE tableField IN ('','')

姑且不说这种 SQL 的效率和可优化和替代性,就当前问题在 MySQL、Greenplum 数据库没有 1000 的限制。

2. 解决方法

解决的方法较多,这里使用的是 JDK8 的 stream 方法,代码如下:

/**
     * 通过 List 数据获取 inStr 字符串(超过 1000 个改成 or in)
     *
     * @param list List对象
     * @return inStr 字符串
     */
    private String getInStrByList(List<Map<String, Object>> list) {
        int listSize = list.size();
        List<Map<String, Object>> tempRecordList;
        // 分段大小(这个数值可以写成参数传递过来)
        int lengthControl = 1000;
        List<String> inStrSegmentList = new ArrayList<>();
        if (listSize <= lengthControl) {
            return list.stream().map(oneMap-> MapUtils.getString(oneMap, "fieldName")).collect(Collectors.joining("','", " table_field in ( '", "' ) "));
        } else {
          // 进行分段
            double number = listSize * 1.0 / lengthControl;
            int n = ((Double) Math.ceil(number)).intValue();
            for (int i = 0; i < n; i++) {
                int iLength = i * lengthControl;
                int end = lengthControl * (i + 1);
                if (end > listSize) {
                    end = listSize;
                }
                tempRecordList = list.subList(iLength, end);
                String inStrSegment = tempRecordList.stream().map(oneMap -> MapUtils.getString(oneMap, "fieldName")).collect(Collectors.joining("','", "'", "'"));
                inStrSegmentList.add(inStrSegment);
            }
        }
        return inStrSegmentList.stream().collect(Collectors.joining(" ) or table_field in ( "," ( table_field in ( "," ) )"));
    }

字符串的使用举例:

<select id="geDataList" parameterType="java.util.Map" resultType="java.util.Map">
        SELECT * FROM table_name
        <where>
            <if test="inStr != null and inStr != ''">
                AND ${inStr}
            </if>
        </where>
    </select>
目录
相关文章
|
2月前
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
|
2月前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
2月前
|
SQL 数据库 索引
SQL中COUNT函数结合条件使用的技巧与方法
在SQL查询中,COUNT函数是一个非常常用的聚合函数,用于计算表中满足特定条件的记录数
|
2月前
|
SQL 存储 数据采集
sql中varchar转number时报错怎么解决
通过上述策略的综合运用,面对VARCHAR到NUMBER的转换挑战,不仅能够游刃有余地解决现有的问题,更能前瞻性地预防未来的隐患。在数字化转型的浪潮中,凭借其高性能、安全稳定的云产品与服务,为各类企业级应用保驾护航,助您轻松驾驭数据的海洋,实现业务的无缝扩展与全球布局。
47 0
|
2月前
|
SQL 关系型数据库 MySQL
SQL日期函数
SQL日期函数
|
3月前
|
SQL 关系型数据库 C语言
PostgreSQL SQL扩展 ---- C语言函数(三)
可以用C(或者与C兼容,比如C++)语言编写用户自定义函数(User-defined functions)。这些函数被编译到动态可加载目标文件(也称为共享库)中并被守护进程加载到服务中。“C语言函数”与“内部函数”的区别就在于动态加载这个特性,二者的实际编码约定本质上是相同的(因此,标准的内部函数库为用户自定义C语言函数提供了丰富的示例代码)
|
4月前
|
SQL 数据处理 数据库
|
4月前
|
SQL Oracle 关系型数据库
SQL 中的大小写处理函数详解
【8月更文挑战第31天】
193 0
|
4月前
|
SQL 数据采集 数据挖掘
为什么要使用 SQL 函数?详尽分析
【8月更文挑战第31天】
62 0
|
4月前
|
SQL 存储 关系型数据库
COALESCE 函数:SQL中的空值处理利器
【8月更文挑战第31天】
721 0