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 06-10-2007, 12:24 AM   #1
Hugo
 
Hugo's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Basic where clause ?

Hi there,

I have a very simple question I guess:

I have two tables, let's say "Family" and "Person" and a "Family"
contains one or more "Person".

If I want to select every Family for which (at least) a Person is called
"Peter", I will write something like this:

select distinct(f.idFamily) from Family as f join Person as p on
p.idFamily=f.idFamily where p.name like 'Peter';

But if now, I want every Family in which no one is called "Peter", I
don't know how to write it. It seems so basic, but I don't even know
where to seek for help on WWW.

Any tips ?

--
Hugo
 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Advertisements
Old 06-10-2007, 12:24 AM   #2
Rik
 
Rik's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Basic where clause ?

Hugo wrote:
> Hi there,
>
> I have a very simple question I guess:
>
> I have two tables, let's say "Family" and "Person" and a "Family"
> contains one or more "Person".
>
> If I want to select every Family for which (at least) a Person is
> called "Peter", I will write something like this:
>
> select distinct(f.idFamily) from Family as f join Person as p on
> p.idFamily=f.idFamily where p.name like 'Peter';
>
> But if now, I want every Family in which no one is called "Peter", I
> don't know how to write it. It seems so basic, but I don't even know
> where to seek for help on WWW.


Seems an Outer Join / where NULL statement.
Something like (untested):

SELECT x.family
FROM (
SELECT f.idFamily AS 'family', p.name AS 'name'
FROM family f
LEFT OUTER JOIN person p ON p.idFamily = f.idFamily
AND p.name LIKE 'peter'
) x
WHERE x.name IS NULL

The trick is the LEFT _OUTER_ JOIN, where the requirement is that
person.name a NOT NULL field is.

Grtz,
--
Rik Wasmus

--
Rik Wasmus


 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Old 06-10-2007, 12:24 AM   #3
Rik
 
Rik's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Basic where clause ?

Rik wrote:
> Hugo wrote:
>> Hi there,
>>
>> I have a very simple question I guess:
>>
>> I have two tables, let's say "Family" and "Person" and a "Family"
>> contains one or more "Person".
>>
>> If I want to select every Family for which (at least) a Person is
>> called "Peter", I will write something like this:
>>
>> select distinct(f.idFamily) from Family as f join Person as p on
>> p.idFamily=f.idFamily where p.name like 'Peter';
>>
>> But if now, I want every Family in which no one is called "Peter", I
>> don't know how to write it. It seems so basic, but I don't even know
>> where to seek for help on WWW.

>
> Seems an Outer Join / where NULL statement.
> Something like (untested):
>
> SELECT x.family
> FROM (
> SELECT f.idFamily AS 'family', p.name AS 'name'
> FROM family f
> LEFT OUTER JOIN person p ON p.idFamily = f.idFamily
> AND p.name LIKE 'peter'
> ) x
> WHERE x.name IS NULL
>


Well, I'm curious, did it work?

Grtz,
--
Rik Wasmus


 
Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Old 06-10-2007, 12:24 AM   #4
Hugo
 
Hugo's Avatar
 
Posts: n/a
My Photos: (0)

Banked:
MK Cash: $

I am Worth:
MK Cash: $
Donate

Recent Blog: None

Default Basic where clause ?

Rik wrote :

>> SELECT x.family
>> FROM (
>> SELECT f.idFamily AS 'family', p.name AS 'name'
>> FROM family f
>> LEFT OUTER JOIN person p ON p.idFamily = f.idFamily
>> AND p.name LIKE 'peter'
>> ) x
>> WHERE x.name IS NULL
>>

>
> Well, I'm curious, did it work?


Sorry to left that unanswered, but I was on holidays last days.

Well in fact I didn't test it yet, but I guess it will work.
Unfortunately, this query is part of a bigger query so I don't know if
it's not too complicated to get good perfs.

Maybe I will need to redifined better my needs, or try some other way to
filter my data. For now I'm quite on standby, but anyway thanks for your
answer !

--
Hugo
 
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
Basic Question P. Tierney Graphics in general 4 06-11-2007 6:35 PM
union in from clause clifden Database 4 05-31-2007 8:45 PM
2 where clause in same statement Mysql 4.2 Xavier Houppertz Database 3 05-31-2007 8:40 PM


Featured Websites




All times are GMT +1. The time now is 12:43 PM.


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