Bug about column references within subqueries used in selects

Started by NikhilSalmost 19 years ago5 messages
#1NikhilS
nikkhils@gmail.com

Hi,

Shouldn't the final command below cause a 'column "b" does not exist error'?

create table update_test (a int, b int);
create table supdate_test(x int, y int);
insert into update_test values (20, 30);
insert into supdate_test values (40, 50);
select a, (select b from supdate_test) from update_test;

a ?column?
---------- -------------------------
20 30

Is the problem with the code in colNameToVar or maybe we should add checks
in transformSubLink?

Regards,
Nikhils
--
EnterpriseDB http://www.enterprisedb.com

#2Merlin Moncure
mmoncure@gmail.com
In reply to: NikhilS (#1)
Re: Bug about column references within subqueries used in selects

On 4/12/07, NikhilS <nikkhils@gmail.com> wrote:

Hi,

Shouldn't the final command below cause a 'column "b" does not exist error'?

create table update_test (a int, b int);
create table supdate_test(x int, y int);
insert into update_test values (20, 30);
insert into supdate_test values (40, 50);
select a, (select b from supdate_test) from update_test;

a ?column?
---------- -------------------------
20 30

Is the problem with the code in colNameToVar or maybe we should add checks
in transformSubLink?

I don't think so...the columns of update_test are visible to the
scalar subquery...that way you can use fields from 'a' to filter the
subquery...
select a, (select y from supdate_test where x = a) from update_test;

merlin

#3NikhilS
nikkhils@gmail.com
In reply to: Merlin Moncure (#2)
Re: Bug about column references within subqueries used in selects

Hi,

On 4/12/07, Merlin Moncure <mmoncure@gmail.com> wrote:

On 4/12/07, NikhilS <nikkhils@gmail.com> wrote:

Hi,

Shouldn't the final command below cause a 'column "b" does not exist

error'?

create table update_test (a int, b int);
create table supdate_test(x int, y int);
insert into update_test values (20, 30);
insert into supdate_test values (40, 50);
select a, (select b from supdate_test) from update_test;

a ?column?
---------- -------------------------
20 30

Is the problem with the code in colNameToVar or maybe we should add

checks

in transformSubLink?

I don't think so...the columns of update_test are visible to the
scalar subquery...that way you can use fields from 'a' to filter the
subquery...
select a, (select y from supdate_test where x = a) from update_test;

Yes this is fine, but in "select columnname from tablename" using column
references of the other involved table is what I am objecting to.

Regards,
Nikhils

--
EnterpriseDB http://www.enterprisedb.com

#4Bort, Paul
pbort@tmwsystems.com
In reply to: NikhilS (#3)
Re: Bug about column references within subqueries used in selects

I don't think so...the columns of update_test are visible to the
scalar subquery...that way you can use fields from 'a'
to filter the
subquery...
select a, (select y from supdate_test where x = a) from
update_test;

Yes this is fine, but in "select columnname from tablename"
using column references of the other involved table is what I
am objecting to.

There's nothing here to object to, the system is acting correctly. Your
column name "b" is ambiguous, and the system takes the column "b" that
exists, rather than returning an error on a column that doesn't exist.
If you were explicit in your column name, you would get an error:

=# select a, (select supdate_test.b from supdate_test) from update_test;
ERROR: No such attribute supdate_test.b

Regards,
Paul

#5Tom Lane
tgl@sss.pgh.pa.us
In reply to: NikhilS (#3)
Re: Bug about column references within subqueries used in selects

NikhilS <nikkhils@gmail.com> writes:

Yes this is fine, but in "select columnname from tablename" using column
references of the other involved table is what I am objecting to.

You can object till you're blue in the face, but this behavior is not
changing because it's *required by spec*. Outer references are a
standard and indeed essential part of SQL.

regards, tom lane