Il ven, 2004-01-23 alle 19:59, Ezra Epstein ha scritto: > > I've got a table called 'main' described as follow > > > > CREATE TABLE main ( > > id_other_table INT, > > value CHAR > > ); > > > > and a table called 'other' described as follow > > > > CREATE TABLE other ( > > id INT PRIMARY KEY, > > value CHAR > > ); > > > > I want to write a query on table 'main' that if 'id_other_table' is null > > returns value from itself, from table 'other' otherwise. > > > > Thank you very much, have a wonderful day! > > > > Marco > > > > I think this post belongs on the SQL list, not the general list. > > Anyway, the SQL you want is: > > =$> select COALESCE(other.value, main.value) AS "value" from main left > outer join other ON main.id_other_table = other.id; > > For example, given: > insert into main (id_other_table, value) values (NULL, 'M'); > insert into main (id_other_table, value) values (1, 'o'); > insert into other (id, value) values (1, 'X'); > The query returns: > value > ------- > M > X > (2 rows)
What if I would like to return more values from table 'other'? Your cool query just return 'other.value', what if I also need 'other.value_two'? Thank you! Marco ---------------------------(end of broadcast)--------------------------- TIP 9: the planner will ignore your desire to choose an index scan if your joining column's datatypes do not match