From: | Richard Klingler <richard(at)klingler(dot)net> |
---|---|
To: | pgsql-sql(at)lists(dot)postgresql(dot)org |
Subject: | Re: Clean up shop database |
Date: | 2022-01-19 12:40:59 |
Message-ID: | 20220119134059286538.4c015b19@klingler.net |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Odd...gives me the same result....
Tried another approach as the ordered is known where to start
from....but still the same:
select p.productid as id, p.name_de as name
from product p, orderitems i,orders
where p.productid = i.orderitems2productid
and i.orderitems2orderid = orders.orderid
and orders.orderid < 14483
and p.pieces < 1
and p.active = 't'
group by id
order by id desc
Still lists products after January 1st 2021...but I know what is going
on....
For example the query above returns as the first product id 47387:
id name
47387 Carpet 70x120cm
47373 Mug Mynte Lavender
Now when I look for order items where this product is:
select o.orderid, o.orderdate, i.orderitemsid, p.productid
from orders o, orderitems i, product p
where p.productid = 47387
and p.productid = i.orderitems2productid
and o.orderid = i.orderitems2orderid
It gives me:
orderid orderdate orderitemsid productid
19157 2021-02-08 88304 47387
17600 2020-10-13 81281 47387
14462 2019-12-28 67561 47387
So the initial query somehow gives all products that have been ordered
at least before January 1st 2021
but not only before that date.
cheers
richard
On Wed, 19 Jan 2022 05:04:09 -0700, Rob Sargent wrote:
> On 1/19/22 04:03, Richard Klingler wrote:
>> Good morning (o;
>>
>>
>> I am in the process of migrating an online shop to another system and
>> therefore
>> also want to clean out products that haven't been re-stocked for a time.
>>
>> Now this simple query returns all order ids younger than 750 days:
>>
>> select orderid, orderdate from orders
>> where (now() - orderdate) < INTERVAL '1000 days'
>> order by orderdate asc
>>
>> So it shows me orders beginning from January 1st 2020...all fine.
>>
>>
>> Now I want to list all products which stock is 0 and have only been
>> ordered
>> before those 750 days..so I use the above query in wrap it in the select
>> with a "not in":
>>
>> select p.productid as id, p.name_de as name
>> from product p, orderitems i, orders
>> where p.productid = i.orderitems2productid
>> and i.orderitems2orderid not in (select orderid from orders where
>> (now() - orderdate) < INTERVAL '750 days')
>> and p.pieces < 1
>> and p.active = 't'
>> group by id
>> order by id desc
> something like this?
>
> select p.productid as id, p.name_de as name
> from product p join orderitems i on p.productid = i.orderitems2productid
> join orders o on i.orderid = o.orderid
> where o.orderdate < 'January 1st 2020'
> and p.pieces < 1
> and p.active = 't'
> group by id
> order by id desc
>>
>>
>> Besides that this query takes over 70 seconds...it also returns
>> products that have been ordered after January 1st 2020.
>>
>> So somehow this "not in" doesn't work as I am expecting it (o;
>>
>>
>> thanks in advance
>> richard
>>
>>
>>
>
>
>
From | Date | Subject | |
---|---|---|---|
Next Message | Rob Sargent | 2022-01-19 12:56:17 | Re: Clean up shop database |
Previous Message | Rob Sargent | 2022-01-19 12:04:09 | Re: Clean up shop database |