Amazon Redshift will no longer support the creation of new Python UDFs starting November 1, 2025. 
  If you would like to use Python UDFs, create the UDFs prior to that date. 
  Existing Python UDFs will continue to function as normal. For more information, see the
  
          blog post
        
IN condition
An IN condition tests a value for membership in a set of values or in a subquery.
Syntax
expression [ NOT ] IN (expr_list | table_subquery)
Arguments
- expression
- 
                        A numeric, character, or datetime expression that is evaluated against the expr_list or table_subquery and must be compatible with the data type of that list or subquery. 
- expr_list
- 
                        One or more comma-delimited expressions, or one or more sets of comma-delimited expressions bounded by parentheses. 
- table_subquery
- 
                        A subquery that evaluates to a table with one or more rows, but is limited to only one column in its select list. 
- IN | NOT IN
- 
                        IN returns true if the expression is a member of the expression list or query. NOT IN returns true if the expression is not a member. IN and NOT IN return NULL and no rows are returned in the following cases: If expression yields null; or if there are no matching expr_list or table_subquery values and at least one of these comparison rows yields null. 
Examples
The following conditions are true only for those values listed:
qtysold in (2, 4, 5) date.day in ('Mon', 'Tues') date.month not in ('Oct', 'Nov', 'Dec')
Optimization for Large IN Lists
To optimize query performance, an IN list that includes more than 10 values is internally evaluated as a scalar array. IN lists with fewer than 10 values are evaluated as a series of OR predicates. This optimization is supported for SMALLINT, INTEGER, BIGINT, REAL, DOUBLE PRECISION, BOOLEAN, CHAR, VARCHAR, DATE, TIMESTAMP, and TIMESTAMPTZ data types.
Look at the EXPLAIN output for the query to see the effect of this optimization. For example:
explain select * from sales QUERY PLAN -------------------------------------------------------------------- XN Seq Scan on sales (cost=0.00..6035.96 rows=86228 width=53) Filter: (salesid = ANY ('{1,2,3,4,5,6,7,8,9,10,11}'::integer[])) (2 rows)