温馨提示×

如何模拟find_in_set功能在Oracle里

小樊
102
2024-06-25 12:40:32
栏目: 云计算

在Oracle中,可以使用INSTR函数来模拟find_in_set功能。INSTR函数用于查找一个字符串在另一个字符串中的位置,如果找到则返回位置,否则返回0。通过在INSTR函数中使用逗号分隔的字符串和目标字符串,可以模拟find_in_set功能。

例如,假设有一个表格包含一个列名为values,其中存储了逗号分隔的字符串,现在需要查找包含特定值的行。可以使用以下查询来实现:

SELECT *
FROM table_name
WHERE INSTR(',' || values || ',', ',value_to_find,') > 0;

在这个查询中,先在values列的字符串两端添加逗号,然后在整个字符串中查找逗号加上要查找的值再加上逗号的位置。如果返回的位置大于0,则表示找到了目标值。

0