Re: [SQL] Conditional Lookup Table with Like
От | sqlQuestions |
---|---|
Тема | Re: [SQL] Conditional Lookup Table with Like |
Дата | |
Msg-id | 1487345617421-5944908.post@n3.nabble.com обсуждение исходный текст |
Ответ на | Re: [SQL] Conditional Lookup Table with Like ("David G. Johnston" <david.g.johnston@gmail.com>) |
Ответы |
Re: [SQL] Conditional Lookup Table with Like
|
Список | pgsql-sql |
Hi David, You got me really close, but I'm still not getting the correct results due to what I've learned is called cartesian product. The result set is being multiplied because of extra rows. Have you seen this before? Here is my query with an example schema. It should only return the first 6 rows in table1 with whichever category is correct. SELECT table1.product_code, table1.date_signed, table1.description, CASE WHEN lower(table1.description) LIKE ('%' || lower(table3.lookup_value) || '%') THEN table3.category ELSE table2.category END FROM table1 LEFT JOIN table2 ON table2.psc_code = table1.product_code LEFT JOIN table3 ON table3.psc_code = table1.product_code WHERE date_signed = '2017-02-01'; create table table1 ( product_code int, date_signed timestamp, description varchar(20) ); insert into table1 (product_code, date_signed, description) values (1, '2017-02-01', 'i have a RED car'), (2, '2017-02-01', 'i have a blue boat'), (3, '2017-02-01', 'i have a dark cat'), (1, '2017-02-01', 'i have a green truck'), (2, '2017-02-01', 'i have a blue rug'), (3, '2017-02-01', 'i have a dark dog'), (1, '2017-02-02', 'i REd NO SHOW'), (2, '2017-02-02', 'i blue NO SHOW'), (3, '2017-02-02', 'i dark NO SHOW'); create table table2 ( psc_code int, category varchar(20) ); insert into table2 (psc_code, category) values (1, 'vehicle'), (2, 'vehicle'); create table table3 ( psc_code int, lookup_value varchar(20), category varchar(20) ); insert into table3 (psc_code, lookup_value, category) values (1, 'fox', 'animal'), (1, 'red', 'color'), (1, 'box', 'shipping'), (2, 'cat', 'animal'); -- View this message in context: http://postgresql.nabble.com/Conditional-Lookup-Table-with-Like-tp5944796p5944908.html Sent from the PostgreSQL - sql mailing list archive at Nabble.com.
В списке pgsql-sql по дате отправления: