Computer Webmaster Gaming Console Graphics Forum

Welcome to the Computer Webmaster Gaming Console Graphics Forum forums.

You are currently viewing our boards as a guest which gives you limited access to view most discussions and access our other features. By joining our free community you will have access to post topics, communicate privately with other members (PM), respond to polls, upload content and access many other special features. Registration is fast, simple and absolutely free so please, join our community today!

If you have any problems with the registration process or your account login, please contact contact us.

MK PitStop Main Earn $25 Earn Money Posting Extras Members Blogs Image Hosting User Pages
Go Back   Computer Webmaster Gaming Console Graphics Forum > Webmaster Forum > Website Coding > Database
Register FAQ/Rules Become A V.I.P. Member Search Today's Posts Mark Forums Read

Database Database problems or need to ask a question? maybe something to do with sql injections or a database software question. Database topics cover MySQL, PostgreSQL, Oracle, SQL Server or anything else related to databases.

Google
Closed Thread
 
LinkBack Thread Tools Display Modes
Old 07-01-2007, 9:35 PM   #1
Ignoramus23298
 
Ignoramus23298's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Outer join?

Sometimes I need to make queries and join tables, knowing that the
other table rows are not always available.

Example:

I do

SELECT question.author, ..., textbooks.picture
WHERE textbooks.id = questions.tb_id

the problem is that sometimes questions.tb_id is NULL (textbook was
not supplied in question), and what I want to have for
textbook.picture is a NULL. But I want the row returned if it exists
in questions.

How would I do it?

o

 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Advertisements
Old 07-01-2007, 9:35 PM   #2
Martijn Tonies
 
Martijn Tonies's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Outer join?

> Sometimes I need to make queries and join tables, knowing that the
> other table rows are not always available.
>
> Example:
>
> I do
>
> SELECT question.author, ..., textbooks.picture
> WHERE textbooks.id = questions.tb_id
>
> the problem is that sometimes questions.tb_id is NULL (textbook was
> not supplied in question), and what I want to have for
> textbook.picture is a NULL. But I want the row returned if it exists
> in questions.
>
> How would I do it?


You gave the answer yourself. By using an OUTER JOIN.

Now, joining tables in the WHERE clause has it drawbacks. Today,
there was a post in this forum asking about it -> read "JOIN vs no JOIN"
and you'll get your answer.


--
Martijn Tonies
Database Workbench - development tool for MySQL, and more!
Upscene Productions
http://www.upscene.com
My thoughts:
http://blog.upscene.com/martijn/
Database development questions? Check the forum!
http://www.databasedevelopmentforum.com


 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Old 07-01-2007, 9:35 PM   #3
Ignoramus23298
 
Ignoramus23298's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Outer join?

On Fri, 19 May 2006 17:18:24 +0200, Martijn Tonies <m.tonies@upscene.removethis.com> wrote:
>> Sometimes I need to make queries and join tables, knowing that the
>> other table rows are not always available.
>>
>> Example:
>>
>> I do
>>
>> SELECT question.author, ..., textbooks.picture
>> WHERE textbooks.id = questions.tb_id
>>
>> the problem is that sometimes questions.tb_id is NULL (textbook was
>> not supplied in question), and what I want to have for
>> textbook.picture is a NULL. But I want the row returned if it exists
>> in questions.
>>
>> How would I do it?

>
> You gave the answer yourself. By using an OUTER JOIN.
>
> Now, joining tables in the WHERE clause has it drawbacks. Today,
> there was a post in this forum asking about it -> read "JOIN vs no JOIN"
> and you'll get your answer.
>
>


Thanks. The query I finally concocted that does what I want, is here:

SELECT
questions.id, userid, tb_id, textbooks.picture
FROM
questions
LEFT JOIN textbooks ON (questions.tb_id = textbooks.id)
ORDER BY date

Do you think that it is sensibly efficient, provided that textbooks.id
is the primary key in textbooks? Textbooks is a relatively small
table, say under 200 entries, questions is bigger, at about 30,000
questions.

I will read join vs. no noin thread now. Thanks.

i

 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Old 07-01-2007, 9:35 PM   #4
Martijn Tonies
 
Martijn Tonies's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Outer join?


> >> Sometimes I need to make queries and join tables, knowing that the
> >> other table rows are not always available.
> >>
> >> Example:
> >>
> >> I do
> >>
> >> SELECT question.author, ..., textbooks.picture
> >> WHERE textbooks.id = questions.tb_id
> >>
> >> the problem is that sometimes questions.tb_id is NULL (textbook was
> >> not supplied in question), and what I want to have for
> >> textbook.picture is a NULL. But I want the row returned if it exists
> >> in questions.
> >>
> >> How would I do it?

> >
> > You gave the answer yourself. By using an OUTER JOIN.
> >
> > Now, joining tables in the WHERE clause has it drawbacks. Today,
> > there was a post in this forum asking about it -> read "JOIN vs no JOIN"
> > and you'll get your answer.
> >
> >

>
> Thanks. The query I finally concocted that does what I want, is here:
>
> SELECT
> questions.id, userid, tb_id, textbooks.picture
> FROM
> questions
> LEFT JOIN textbooks ON (questions.tb_id = textbooks.id)
> ORDER BY date
>
> Do you think that it is sensibly efficient, provided that textbooks.id
> is the primary key in textbooks? Textbooks is a relatively small
> table, say under 200 entries, questions is bigger, at about 30,000
> questions.


I think it will be efficient, yes.

When in doubt, read the query plan.

> I will read join vs. no noin thread now. Thanks.



--
Martijn Tonies
Database Workbench - development tool for MySQL, and more!
Upscene Productions
http://www.upscene.com
My thoughts:
http://blog.upscene.com/martijn/
Database development questions? Check the forum!
http://www.databasedevelopmentforum.com


 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Old 07-01-2007, 9:35 PM   #5
Ignoramus24136
 
Ignoramus24136's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Outer join?

On Sun, 21 May 2006 18:07:15 +0200, Martijn Tonies <m.tonies@upscene.removethis.com> wrote:
>
>> >> Sometimes I need to make queries and join tables, knowing that the
>> >> other table rows are not always available.
>> >>
>> >> Example:
>> >>
>> >> I do
>> >>
>> >> SELECT question.author, ..., textbooks.picture
>> >> WHERE textbooks.id = questions.tb_id
>> >>
>> >> the problem is that sometimes questions.tb_id is NULL (textbook was
>> >> not supplied in question), and what I want to have for
>> >> textbook.picture is a NULL. But I want the row returned if it exists
>> >> in questions.
>> >>
>> >> How would I do it?
>> >
>> > You gave the answer yourself. By using an OUTER JOIN.
>> >
>> > Now, joining tables in the WHERE clause has it drawbacks. Today,
>> > there was a post in this forum asking about it -> read "JOIN vs no JOIN"
>> > and you'll get your answer.
>> >
>> >

>>
>> Thanks. The query I finally concocted that does what I want, is here:
>>
>> SELECT
>> questions.id, userid, tb_id, textbooks.picture
>> FROM
>> questions
>> LEFT JOIN textbooks ON (questions.tb_id = textbooks.id)
>> ORDER BY date
>>
>> Do you think that it is sensibly efficient, provided that textbooks.id
>> is the primary key in textbooks? Textbooks is a relatively small
>> table, say under 200 entries, questions is bigger, at about 30,000
>> questions.

>
> I think it will be efficient, yes.
>
> When in doubt, read the query plan.


I will definitely try messing with query plans. Thank you very much.

I just say

EXPLAIN SELECT ...

is that right?

i

>> I will read join vs. no noin thread now. Thanks.

>
>


 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Old 07-01-2007, 9:35 PM   #6
Martijn Tonies
 
Martijn Tonies's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Outer join?


> > I think it will be efficient, yes.
> >
> > When in doubt, read the query plan.

>
> I will definitely try messing with query plans. Thank you very much.
>
> I just say
>
> EXPLAIN SELECT ...
>
> is that right?


Yes.


--
Martijn Tonies
Database Workbench - development tool for MySQL, and more!
Upscene Productions
http://www.upscene.com
My thoughts:
http://blog.upscene.com/martijn/
Database development questions? Check the forum!
http://www.databasedevelopmentforum.com


 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Featured Websites
Free Space
Free Space
Free Space Free Space
Closed Thread
Tags: ,




Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
 
Thread Tools
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

vB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On

Similar Threads
Thread Thread Starter Forum Replies Last Post
Full OUTER Paul Lautman Database 1 07-01-2007 9:35 PM
Left Outer Join Jared Database 0 07-01-2007 9:33 PM
Hi join in the fun with nbc N&D1954 Affiliate Programs 0 06-12-2007 7:54 PM
WE PAY FOR YOU TO JOIN ! ! Georgie Building An Internet Business 0 05-29-2007 1:40 AM
WE PAY FOR YOU TO JOIN ! ! UCE Building An Internet Business 0 05-29-2007 1:38 AM


Featured Websites




All times are GMT +1. The time now is 12:17 AM.


Powered by: vBulletin Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO 3.0.0
Cheap Computers
MK PitStop Copyright 2005 - 2008

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98