拆分字符串并计算 Teradata SQL
Split String and Count Teradata SQL
我想拆分列 'ASPCT_VLU_NM' 和给定时间范围内时间戳的出现次数。
例如 return 在 1537160520286 和 1537190520286.
之间出现超过 3 次的 ID
在下面的示例中,这些是时间戳:
如果您使用的是 Teradata 14 或更高版本,那么您可以利用此处的 STRTOK
功能:
SELECT
ID
FROM yourTable
WHERE
CAST(STRTOK(ASPCT_VLU_NM, ',', 4) AS BIGINT) BETWEEN 1537160520286 AND 1537190520286
GROUP BY
ID
HAVING
COUNT(*) > 3;
注意:您可能需要认真考虑更改 table 设计,特别是 不 在 ASPCT_VLU_NM
列中存储 CSV 数据。相反,将每个 CSV 值放入单独的 row/column.
我想拆分列 'ASPCT_VLU_NM' 和给定时间范围内时间戳的出现次数。 例如 return 在 1537160520286 和 1537190520286.
之间出现超过 3 次的 ID在下面的示例中,这些是时间戳:
如果您使用的是 Teradata 14 或更高版本,那么您可以利用此处的 STRTOK
功能:
SELECT
ID
FROM yourTable
WHERE
CAST(STRTOK(ASPCT_VLU_NM, ',', 4) AS BIGINT) BETWEEN 1537160520286 AND 1537190520286
GROUP BY
ID
HAVING
COUNT(*) > 3;
注意:您可能需要认真考虑更改 table 设计,特别是 不 在 ASPCT_VLU_NM
列中存储 CSV 数据。相反,将每个 CSV 值放入单独的 row/column.