Communities for your favorite technologies. Explore all Collectives
Stack Overflow for Teams is now called Stack Internal. Bring the best of human thought and AI automation together at your work.
Bring the best of human thought and AI automation together at your work. Learn more
Find centralized, trusted content and collaborate around the technologies you use most.
Stack Internal
Knowledge at work
Bring the best of human thought and AI automation together at your work.
I want to use a substring in a CASE statement that if it returns true then it will return whatever is in the THEN clause, such as:
CASE
true
THEN
CASE WHEN substring(name, '\d\s\d{8}') THEN 'Long Name' END
Since you only need a boolean result, use a simple regular expression instead of the function substring():
substring()
CASE WHEN name ~ '\d\s\d{8}' THEN 'Long Name' END
You can use the same regex pattern. Defaults to NULL if the pattern is not found.
NULL
Add a comment
If you need the substring() you then need to evaluate the string that is returned by the substring function:
case when substring('foobar' from '\d\s\d{8}') IS NOT NULL then 'Long Name' else 'Short Name' end
Required, but never shown
By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.
Start asking to get answers
Find the answer to your question by asking.
Explore related questions
See similar questions with these tags.