Re: [SQL] Conditional Lookup Table with Like - Mailing list pgsql-sql

From sqlQuestions
Subject Re: [SQL] Conditional Lookup Table with Like
Date
Msg-id 1487345617421-5944908.post@n3.nabble.com
Whole thread Raw
In response to Re: [SQL] Conditional Lookup Table with Like  ("David G. Johnston" <david.g.johnston@gmail.com>)
Responses Re: [SQL] Conditional Lookup Table with Like  ("David G. Johnston" <david.g.johnston@gmail.com>)
List 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 by date:

Previous
From: sqlQuestions
Date:
Subject: Re: [SQL] Conditional Lookup Table with Like
Next
From: "David G. Johnston"
Date:
Subject: Re: [SQL] Conditional Lookup Table with Like