Ik ben bang dat het niet zo werkt:
SELECT * from myTable where name in (inputStr);
U kunt dynamische SQL gebruiken, zoals in het antwoord van @Bob Jarvis, of u kunt het volgende doen:
SELECT * FROM myTable WHERE REGEXP_LIKE(name, '^(' || REPLACE(inputStr, ',', '|') || ')$');
De moeilijkheid met dit laatste is dat in Oracle een reguliere expressie maximaal 512 bytes lang kan zijn. Dus uw inputStr
zou beperkt zijn tot 508 bytes (aangezien we vier bytes toevoegen voor de ankers en de groepering).