From: | Frank Bax <fbax(at)sympatico(dot)ca> |
---|---|
To: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: update on join ? |
Date: | 2007-11-22 03:34:24 |
Message-ID: | 4744F8C0.7040106@sympatico.ca |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Andreas wrote:
> I'd like to update a table efficiently where the relevant select-info
> is in another table that is foreign-linked.
>
> Stupid example. 2 tables:
> things (thing_id integer, name varchar(100), color varchar(100))
> inventory (item_id integer, thing_fk integer references things
> (thing_id), number)
>
> For some reason I'd want to set the number of every red item to 0.
> This inventory doesn't contain the color but the foreign key to the
> other table where the color is found.
>
> I tried
>
> UPDATE things JOIN inventory ON things.thing_id = inventory.thing_fk
> SET number = 0
> WHERE color = 'red'
>
> PSQL didn't like the JOIN though.
> It works like this:
>
> UPDATE inventory
> SET number = 0
> WHERE thing_fk IN (SELECT thing_id FROM things WHERE color = 'red')
>
> It's effective but is it efficient, too?
What about:
UPDATE things, inventory
SET number = 0
WHERE color = 'red'
AND things.thing_id = inventory.thing_fk
From | Date | Subject | |
---|---|---|---|
Next Message | Richard Broersma Jr | 2007-11-22 03:38:01 | Re: update on join ? |
Previous Message | Andreas | 2007-11-22 02:58:50 | update on join ? |