On Tuesday 26 Nov 2002 9:43 am, patrick wrote:
> Greetings,
>
> I'm not sure what the correct behavior is here but the observed
> behavior seems "wrong" (or at least undesirable).
>
> I have a few tables and a view on one of the tables selecting
> entries that may be purged.
>
> My delete statement uses the view to delete data from one of the
> tables.  Like so:
>
>   delete from tab1 where id1 in ( select id from view1 );
>
> Assume that the view doesn't have a field named "id".  The select
> statement alone would cause an error.  However, in this context it
> doesn't and the delete statement deletes everything from tab1.
>
> Is this a bug in PostgreSQL or an "As Designed" feature?

Don't look right to me, and I still see it here in 7.2 and the 7.3 beta I've 
got (note - not most recent). I don't think it's in the subselect itself - 
what's happening is when you do

DELETE FROM ttab_title_selection 
WHERE tsel_id IN (SELECT xxx FROM tview_title);

the xxx is binding to the outside query (the DELETE). If you change your 
definition of ttab_title_selection to use tsel_id rather than title_id this 
will be clearer. You can get the same with ranking:

DELETE FROM ttab_title_selection 
WHERE ranking IN (SELECT ranking FROM tview_title);

I'm guessing it gets parsed down to:

DELETE FROM ttab_title_selection WHERE ranking IN (ranking);

which of course matches everything.


-- 
  Richard Huxton

---------------------------(end of broadcast)---------------------------
TIP 6: Have you searched our list archives?

http://archives.postgresql.org

Reply via email to