问题
I'm using case statement and REGEXP_CONTAINS.Just wanted to see if the following order will give me the correct output.
(CASE
WHEN REGEXP_CONTAINS(AdSet, '(?i)BUS') THEN "BUS"
WHEN REGEXP_CONTAINS(AdSet, '(?i)BRA') THEN "BR"
WHEN REGEXP_CONTAINS(AdSet, '(?i)DIG') THEN "TR"
WHEN REGEXP_CONTAINS(AdSet, '(?i)INS') THEN "INS"
WHEN REGEXP_CONTAINS(AdSet, '(?i)INV') THEN "INV"
WHEN REGEXP_CONTAINS(AdSet, '(?i)SAV') THEN "SAV"
WHEN REGEXP_CONTAINS(AdSet, '(?i)TRA') THEN "TR"
WHEN REGEXP_CONTAINS(AdSet, '(?i)CC') THEN "CC"
WHEN REGEXP_CONTAINS(AdSet, '(?i)HL') THEN "HL"
WHEN REGEXP_CONTAINS(AdSet, '(?i)BR') THEN "BR"
END) as pf
回答1:
Seems correct if you want case insensitive search for the keyword, while in general, string functions are more efficient than REGEX functions, consider to:
REGEXP_CONTAINS(AdSet, '(?i)BUS') THEN "BUS"
=>
STRPOS(UPPER(AdSet), 'BUS') <> 0 THEN "BUS"
来源:https://stackoverflow.com/questions/63591800/regexp-contains-order-and-case-statement-in-bigquery