一些SQL小技巧,不定期更新...

要将查询结果作为IN语句的查询条件,查询结果作为子查询,并在主查询中使用IN子句。

sql 复制代码
SELECT table_ids
    FROM cdc_table_sync
    WHERE sync_id = 'FLINK_CDC_SYNC_TABLE_198';

结果为:c2a9f78ecc3f6a6c97c12956d25e1adc,24d883d4a419578d09dd3801f001b93e,f3e569a5c68023c76b5bb22e25768739,df9e3fe91219ce1d042ee84a0b4b58ea,465d014da17e858fd16bca733141126a,6572ff4511b9164bffb1bfbc480d364e

这样的字符串

sql 复制代码
SELECT *
FROM your_table
WHERE column_name IN (
  SELECT split_part(result, ',', generate_series(1, array_length(string_to_array(result, ','), 1))) AS element
  FROM (
    SELECT string_agg(quote_literal(table_ids) || ',', '') AS result
    FROM cdc_table_sync
    WHERE sync_id = 'FLINK_CDC_SYNC_TABLE_198'
  ) subquery
);

your_table替换表名,column_name`替换为进行IN匹配的列名。

这里将首先使用之前提供的查询语句,将查询结果以逗号分隔并加上单引号。然后,使用string_to_array函数将结果拆分为一个数组。接下来,通过generate_series函数生成一个序列,用来获取数组中的每个元素。最后,使用split_part函数将每个元素分别作为子查询的结果,并在主查询中使用IN子句。

当主查询执行时,它将比对指定列的值与子查询的结果,如果匹配则返回相应的行。

相关推荐
CV艺术家5 分钟前
java原mysql切换国产达梦数据库
数据库·mysql
好大哥呀5 分钟前
如何在Spring Boot中配置数据库连接?
数据库·spring boot·后端
xcLeigh11 分钟前
IoTDB数据订阅API实战:实时消费数据+TsFile订阅全攻略
数据库·api·iotdb·数据备份·tsfile·数据订阅
许杰小刀14 分钟前
使用 Python 将 Excel 数据批量导入到数据库中(SQLite)
数据库·python·excel
一个天蝎座 白勺 程序猿16 分钟前
Apache IoTDB(16):时序数据库的数据删除从单点精准清除到企业级数据生命周期管理
数据库·apache·时序数据库·iotdb
努力进修19 分钟前
【MySQL】90% 的 MySQL 性能问题都和它有关!索引的正确打开方式,看完少走 3 年弯路
数据库·mysql
架构师老Y19 分钟前
005、数据库选型与ORM技术:SQLAlchemy深度解析
数据库·python
清水白石00821 分钟前
Python 在数据栈中的边界:何时高效原型、何时切换到 SQL、Spark、Rust 或数据库原生能力
数据库·python·自动化
dishugj22 分钟前
sqlplus / as sysdba登录数据库报错ora-01017解决办法
数据库·oracle
小陈工4 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python