DROP TABLE dups IF EXISTS;
CREATE TABLE dups(pk INTEGER NOT NULL PRIMARY KEY,val VARCHAR(10) NOT NULL);
INSERT INTO dups VALUES (1, 'first');
INSERT INTO dups VALUES (2, 'second');
INSERT INTO dups VALUES (3, 'third');
INSERT INTO dups VALUES (4, 'first');
INSERT INTO dups VALUES (5, 'first');
INSERT INTO dups VALUES (6, 'second');
SELECT a.pk, a.val FROM dups a WHERE a.pk in (SELECT sa.pk FROM dups sa, dups sb WHERE sa.val=sb.val AND sa.pk!=sb.pk);
SELECT sa.pk FROM dups sa, dups sb WHERE sa.val=sb.val AND sa.pk!=sb.pk;
/*c5*/SELECT a.pk, a.val FROM dups a WHERE a.pk IN (1, 2, 4, 5, 6);
/*c2*/SELECT a.pk, a.val FROM dups a WHERE (a.pk, a.val) IN ((1, 'first'), (5, 'first'));

-- IN with nulls
/*c0*/SELECT * FROM dups WHERE null IN (1, 2)
/*c0*/SELECT * FROM dups WHERE null IN (null, 2)
/*c0*/SELECT * FROM dups WHERE null IN (null, 2)
/*c0*/SELECT * FROM dups WHERE null IN (null, null)
/*c0*/SELECT * FROM dups WHERE cast(null AS INT) IN (null, null)
/*c1*/SELECT * FROM dups WHERE pk IN (null, 1)
/*c0*/SELECT * FROM dups WHERE pk IN (null, null)

-- ALL
/*r
 1,first
 4,first
 5,first
*/SELECT a.pk, a.val FROM dups a WHERE a.val =
  ALL(SELECT sa.val FROM dups sa WHERE sa.val = 'first') ORDER BY a.pk;
/*r
 1,first
 2,second
 3,third
 4,first
 5,first
 6,second
*/SELECT a.pk, a.val FROM dups a WHERE a.val >=  ALL(SELECT sa.val FROM dups sa WHERE sa.val = 'first') ORDER BY a.pk;
/*r
 2,second
 3,third
 6,second
*/SELECT a.pk, a.val FROM dups a WHERE a.val > ALL(SELECT sa.val FROM dups sa WHERE sa.val = 'first') ORDER BY a.pk;
/*r
 1,first
 2,second
 4,first
 5,first
 6,second
*/SELECT a.pk, a.val FROM dups a WHERE a.val
  <= ALL(SELECT sa.val FROM dups sa WHERE sa.val = 'second') ORDER BY a.pk;
/*r
 1,first
 2,second
 4,first
 5,first
 6,second
*/SELECT a.pk, a.val FROM dups a WHERE a.val
 < ALL(SELECT sa.val FROM dups sa WHERE sa.val = 'third') ORDER BY a.pk;

/*r
 1,first
 4,first
 5,first
*/SELECT a.pk, a.val FROM dups a WHERE a.val
 <= ALL(SELECT sa.val FROM dups sa) ORDER BY a.pk;

-- ANY

/*r
 1,first
 2,second
 4,first
 5,first
 6,second
*/SELECT a.pk, a.val FROM dups a WHERE a.val
 < ANY(SELECT sa.val FROM dups sa) ORDER BY a.pk;

/*r
 2,second
 3,third
 6,second
*/SELECT a.pk, a.val FROM dups a WHERE a.val
 > ANY(SELECT sa.val FROM dups sa) ORDER BY a.pk;

/*r
 1,first
 2,second
 3,third
 4,first
 5,first
 6,second
*/SELECT a.pk, a.val FROM dups a WHERE a.val
 <= ANY(SELECT sa.val FROM dups sa) ORDER BY a.pk;

/*c0*/SELECT a.pk, a.val FROM dups a WHERE a.val
 <= ANY(SELECT CAST(NULL AS CHAR) FROM dups sa) ORDER BY a.pk;

/*c0*/SELECT a.pk, a.val FROM dups a WHERE a.val
 <= ANY(SELECT NULL FROM dups sa) ORDER BY a.pk;

/*c0*/SELECT a.pk, a.val FROM dups a WHERE a.val
 <= ANY(SELECT CAST(NULL AS CHAR) FROM dups sa WHERE sa.val ='fourth') ORDER BY a.pk;

/*c0*/SELECT a.pk, a.val FROM dups a WHERE a.val
 <= ANY(SELECT NULL FROM dups sa WHERE sa.val ='fourth') ORDER BY a.pk;

-- non-correlated single value
/*r
 1,first
 4,first
 5,first
*/SELECT a.pk, a.val FROM dups a WHERE a.val
 = (SELECT sa.val FROM dups sa WHERE sa.pk = 4) ORDER BY a.pk;
-- bug item #1100384
drop table a if exists;
drop table b if exists;
drop table m if exists;
create table a(a_id integer);
create table b(b_id integer);
create table m(m_a_id integer, m_b_id integer);
insert into a(a_id) values(1);
insert into b(b_id) values(10);
insert into m(m_a_id, m_b_id) values(1, 5);
insert into m(m_a_id, m_b_id) values(1, 10);
insert into m(m_a_id, m_b_id) values(1, 20);
/*r1,10*/select a.a_id, b.b_id from a, b
 where a.a_id in (select m.m_a_id from m where b.b_id = m.m_b_id);
/*r1,10*/select a.a_id, b.b_id from a join b on
 a.a_id in (select m.m_a_id from m where b.b_id = m.m_b_id);
/*u1*/update m set m_a_id = 2 where m_b_id in (1, 10, 100);
/*r
 1,5
 2,10
 1,20
*/select * from m order by m_b_id

--
DROP TABLE T IF EXISTS;
CREATE TABLE T(C VARCHAR_IGNORECASE(10));
INSERT INTO T VALUES ('felix');
/*r
 felix
*/SELECT * FROM T WHERE C IN ('Felix', 'Feline');
/*c0*/SELECT * FROM T WHERE C IN ('Pink', 'Feline');
DROP TABLE T;
CREATE TABLE T(C CHAR(10));
INSERT INTO T VALUES ('felix');
/*c1*/SELECT * FROM T WHERE C IN ('felix', 'pink');
DROP TABLE T;

--
create table t (c1 int, c2 int, primary key(c2, c1))
insert into t values (10, 20), (11, 21), (21, 32)
/*r
 11,21
*/select * from t where (c1, c2) in ((11, 21))
/*r
 11,21
*/select * from t where (c2, c1) in ((21, 11))

update t set c2 = 31 where (c2, c1) in ((21, 11))
--
drop table if exists test_trips;
drop table if exists test_routes;
create table test_routes (agencyId varchar(50) not null, id varchar(255)
 not null, primary key (agencyId, id));
create table test_trips (agencyId varchar(50) not null, id varchar(255) not
 null, route_agencyId varchar(50), route_id varchar(255), primary key
 (agencyId, id));
alter table test_trips add constraint test_trips_routes foreign key
 (route_agencyId, route_id) references test_routes;
insert into test_routes (agencyId, id) values ('a','r1'),('a','r2');
insert into test_trips (agencyId, id,route_agencyId,route_id) values
 ('a','1','a','r1'),('a','2','a','r2');
/*c1*/select * from test_trips where (route_agencyId, route_id) in (('a','r1'));
/*c2*/select * from test_trips where (route_agencyId, route_id) in (values('a','r1'), ('a','r2'));

create table inv_txn (id bigint primary key, inv_account_target bigint);
create table inv_element (id bigint primary key, inv_txn bigint, product bigint, quantity bigint);

insert into inv_txn values (1, 1);
insert into inv_txn values(2, 2);

insert into inv_element values (1, 1, 1, 25);
insert into inv_element values (2, 1, 1, 10);
insert into inv_element values (3, 1, 2, 15);
insert into inv_element values (4, 1, 2, 5);
insert into inv_element values (5, 1, 3, 50);
insert into inv_element values (6, 1, 3, 30);
insert into inv_element values (7, 1, 4, 5);
insert into inv_element values (8, 1, 4, 15);
insert into inv_element values (9, 1, 5, 100);
insert into inv_element values (10, 1, 6, 75);
insert into inv_element values (11, 2, 1, 25);
insert into inv_element values (12, 2, 1, 10);
insert into inv_element values (13, 2, 2, 15);
insert into inv_element values (14, 2, 2, 5);
insert into inv_element values (15, 2, 3, 50);
insert into inv_element values (16, 2, 3, 30);
insert into inv_element values (17, 2, 4, 5);
insert into inv_element values (18, 2, 4, 15);
insert into inv_element values (19, 2, 5, 100);
insert into inv_element values (20, 2, 6, 75);
-- query must show the same values in columns using equality or IN predicates
select
        inv_element.product,
        sum(casewhen(inv_txn.inv_account_target in (1), quantity, 0)) as badtarget1qty,
        sum(casewhen(inv_txn.inv_account_target = 1, quantity, 0)) as goodtarget1qty,
        sum(casewhen(inv_txn.inv_account_target in (2), quantity, 0)) as badtarget2qty,
        sum(casewhen(inv_txn.inv_account_target = 2, quantity, 0)) as goodtarget2qty,
        sum(casewhen(inv_txn.inv_account_target in (1, 2), quantity, 0)) as badtotalqty,
        sum(casewhen(inv_txn.inv_account_target = 1 or inv_txn.inv_account_target = 2, quantity, 0)) as goodtotalqty
  from inv_txn
        inner join inv_element on inv_txn.id = inv_element.inv_txn
  group by product;
