PostgreSQL删除行,其中等于用逗号分隔的字符串

问题描述

我是sql的初学者,我想通过执行查询删除一些行。

例如,我有一张桌子:

     ID                  │           Type            │ 
─────────────────────────┼───────────────────────────┼
 220                     │ aaa                       │ 
 220                     │ bbb                       │
 220                     │ ccc                       │ 
 220                     │ ddd                       │ 
 220                     │ eee                       │ 
 220                     │ fff                       │ 

我有一个用逗号分隔的字符串:

aaa,bbb,fff,ddd

我希望删除所有ID等于220且Type等于字符串中的值的行。

我该怎么办。

非常感谢

解决方法

一个选项将字符串拆分为一个数组,然后使用any()

delete 
from mytable 
where id = 220 and type = any(string_to_array('aaa,bbb,fff,ddd',',' ))