21

For example, one column in my table is an array, I want to check if that column contains an element that contains substring "denied" (so elements like "denied at 12:00 pm", "denied by admin" will all count, I believe I will have to use "like" to identify the pattern). How to write sql for this?

Martin Traverso
  • 4,731
  • 15
  • 24
daydayup
  • 2,049
  • 5
  • 22
  • 47

4 Answers4

32

Use presto's array functions:

  • filter(), which returns elements that satisfy the given condition
  • cardinality(), which returns the size of an array:

Like this:

where cardinality(filter(myArray, x -> x like '%denied%')) > 0
Bohemian
  • 412,405
  • 93
  • 575
  • 722
14

In newer versions of PrestoSQL (now known as Trino), you can use the any_match function:

WHERE any_match(column, e -> e like '%denied%')
user5305519
  • 3,008
  • 4
  • 26
  • 44
Martin Traverso
  • 4,731
  • 15
  • 24
2

See array operator docs here

contains(array_column,'denied')

twoy
  • 53
  • 7
  • 2
    this does not answer the question. According to the doc, the `CONTAINS` operator only looks for exact matches. – bmarcov Apr 29 '20 at 10:58
0

We can use strpos(returns starting position of substring and 0 if not found) here. (documentation)

where strpos(array_column,'denied')>0
AGVG
  • 36
  • 4