Bruce,

Try building your join table by table.. start with

SELECT
        fields....
FROM
        universityTBL LEFT JOIN university_urlTBL ON
                universityTBL.ID = university_urlTBL.universityID
WHERE
        universityTBL.ID = 40;

Then if that works.. chain on your next table and fields and slowly add them
until you have the lot..
This is a good technique to find where your joins are going wrong.

Regards,
Lachlan

-----Original Message-----
From: bruce [mailto:[EMAIL PROTECTED]
Sent: Tuesday, 10 August 2004 12:27 PM
To: 'Lachlan Mulcahy'
Subject: RE: left join issues!!!



 universityTBL(
        name varchar(50) not null default '',
        city varchar(20)  default '',
        stateVAL varchar(5) not null,
        userID int(10) not null default'',
        ID int(10) not null auto_increment,
        primary key (ID),    -------------------------+
        unique key (name)                             |
        )type =bdb;                                   |

 university_urlTBL(
        universityID int(10) not null default '', <<--+
        urltype int(5) not null,
        url varchar(50) not null default '',
        userID int(10) not null default'',
        actionID int(5) null default '',
        status int(5) null default '',
        ID int(10) not null auto_increment,
        primary key (ID),>----------------------------------+
--        unique key (url, urltype),                        |
        unique key (url, universityID, urltype)             |
        )type =bdb;


userTBL(
        name varchar(20) not null,                          |
        email varchar(20) not null,                         |
        phone varchar(20) not null,                         |
        city varchar(20) not null,                          |
        state varchar(20) not null,                         |
        usergroup varchar(10) not null,                     |
        userlevel varchar(10) not null,                     |
        ID int(5) not null auto_increment,  >>----------+   |
        unique key (ID)                                 |   |
        )type =bdb;                                     |   |


 parsefileTBL(                                              |
        university_urlID int(5) not null default '',<<------+
        filelocation varchar(50) not null default '',   |
        name varchar(50) not null default '',           |
--      urltype int(2) not null,                        |
        userID int(10) not null default '',<<<<<<<<<<---+
        fileID int(10) not null auto_increment,>>>---------+
        primary key (fileID),                              |
        unique key (university_urlID, filelocation)        |
        )type =bdb;


create table parsefilestatusTBL(                           |
        userID int(5) not null default '',                 |
        testdate timestamp not null,                       |
        action int(5) not null default '',                 |
        statusID int(5) not null default '',               |
        fileID int(10) not null, <<<<----------------------+
        unique key (fileID, testdate)
        )type =bdb;


universityTBL
name     id
auburn   40

university_urlTBL
universityid       id
40                 157
40                 158
40                 159
40                 160

parsefileTBL
university_urlID    userID      fileID
157                   NULL        1
158                   NULL        2
159                   NULL        3
160                   1           4

userTBL
name    id
tom     1

this is a sample of what the db/tbl looks like for
auburn/universityTBL.ID=40



-----Original Message-----
From: Lachlan Mulcahy [mailto:[EMAIL PROTECTED]
Sent: Monday, August 09, 2004 6:02 PM
To: [EMAIL PROTECTED]
Subject: RE: left join issues!!!


Bruce,

What do you get when you do this:

SELECT
        *
FROM
        university_urlTBL
WHERE
        universityID = 40;


Lachlan

-----Original Message-----
From: bruce [mailto:[EMAIL PROTECTED]
Sent: Tuesday, 10 August 2004 10:46 AM
To: 'Lachlan Mulcahy'
Subject: RE: left join issues!!!


i tried your suggestion....

i got the following...
select p2.statusID as parseStatus,
    -> p2.action as parseAction,
    -> p1.userID,
    -> u3.ID,
    -> u3.url as schoolUrl,
    -> u3.urltype as urlType,
    -> u1.name as school,
    -> u1.city as city,
    -> u1.stateVAL as state
    -> from universityTBL as u1
    -> left join university_urlTBL as u3
    -> on u1.ID = u3.universityID
    -> left join parsefileTBL as p1
    ->  on u3.ID = p1.university_urlID
    -> left join parsefilestatusTBL as p2
    ->  on p1.fileID = p2.fileID
    -> where u1.ID = '40';
+-------------+-------------+--------+------+-----------+---------+--------+
-------------------+-------+
| parseStatus | parseAction | userID | ID   | schoolUrl | urlType | school |
city              | state |
+-------------+-------------+--------+------+-----------+---------+--------+
-------------------+-------+
|        NULL |        NULL |   NULL | NULL | NULL      |    NULL | www    |
Auburn University | AL    |
+-------------+-------------+--------+------+-----------+---------+--------+
-------------------+-------+


which is not what i was going for !!!!!


-----Original Message-----
From: Lachlan Mulcahy [mailto:[EMAIL PROTECTED]
Sent: Monday, August 09, 2004 5:21 PM
To: [EMAIL PROTECTED]
Subject: RE: left join issues!!!


Hi Bruce,

I haven't reconstructed your database to test for sure, but I think your
problem is stemming from the way your joins are working.

First of all, since you are left joining to the university_urlTBL, you will
also need to left join to any tables you join from that table. If you don't
do this then when a record is not found in the university_urlTBL you'll get
your NULLs which you are then doing an inner join on to the parsefileTBL,..
subsequently there will be no record in the parsefileTBL matching the NULL
and in turn you will lose the whole record. This seems to negate the point
of the LEFT JOIN in the first place since unless a real record is found in
university_urlTBL to match you won't get a result anyhow.

Essentially you want to change all your joins to left join and change your
WHERE clause to refer to the universityTBL only.

Try this:

SELECT
        p2.statusID as parseStatus,
        p2.action as parseAction,
        u2.name,
        p1.userID,
        u3.ID,
        u3.url as schoolUrl,
        u3.urltype as urlType,
        u1.name as school,
        u1.city as city,
        u1.stateVAL as state,
FROM
        universityTBL as ul
        LEFT JOIN university_urlTBL as u3
                ON u1.ID = u3.universityID
        LEFT JOIN parsefileTBL as p1
                ON u3.ID = p1.university_urlID
        LEFT JOIN parsefilestatusTBL as p2
                ON p1.fileID = p2.fileID
        LEFT JOIN userTBL as u2
                ON p1.userID = u2.ID
WHERE
        u1.ID = '40';

As I said, I haven't reconstructed the database, but this is the way I would
try,.. As a general rule if you are chaining up your joins, every join after
the first left join should also be a left join unless of course you plan on
joining on NULLs.

Hope this helps :)

Regards,
Lachlan


-----Original Message-----
From: bruce [mailto:[EMAIL PROTECTED]
Sent: Tuesday, 10 August 2004 7:16 AM
To: [EMAIL PROTECTED]
Subject: left join issues!!!


hi...

sorry for the length of this post!!

i have the following, that i somehow managed to get working at some point,
but i've screwed it up!!!

basically i have a number of tables, that i'm trying to join. the tables
are:


universityTBL(
        name varchar(50) not null default '',
        city varchar(20)  default '',
        stateVAL varchar(5) not null,
        userID int(10) not null default'',
        ID int(10) not null auto_increment,
        primary key (ID),
        unique key (name)
        )type =bdb;

 university_urlTBL(
        universityID int(10) not null default '',
        urltype int(5) not null,
        url varchar(50) not null default '',
        userID int(10) not null default'',
        actionID int(5) null default '',
        status int(5) null default '',
        ID int(10) not null auto_increment,
        primary key (ID),
        unique key (url, universityID, urltype)
        )type =bdb;

 userTBL(
        name varchar(20) not null,
        email varchar(20) not null,
        phone varchar(20) not null,
        city varchar(20) not null,
        state varchar(20) not null,
        usergroup varchar(10) not null,
        userlevel varchar(10) not null,
        ID int(5) not null auto_increment,
        unique key (ID)
        )type =bdb;


parsefileTBL(
        university_urlID int(5) not null default '',
        filelocation varchar(50) not null default '',
        name varchar(50) not null default '',
--      urltype int(2) not null,
        userID int(10) not null default '',
        fileID int(10) not null auto_increment,
        primary key (fileID),
        unique key (university_urlID, filelocation)
        )type =bdb;


 parsefilestatusTBL(
        userID int(5) not null default '',
        testdate timestamp not null,
        action int(5) not null default '',
        statusID int(5) not null default '',
        fileID int(10) not null,
        unique key (fileID, testdate)
        )type =bdb;


each table links:
 universityTBL.ID -> university_urlTBL.universityID
 university_urlTBL.ID -> parsefileTBL.university_urlID
 parsefileTBL.fileID -> parsefilestatusTBL.fileID
 userTBL.ID -> parsefileTBL.userID

universityTBL has a unique ID

within the university_urlTBL, the ID from the universityTBL might point to
multiple records (basically, a university might have multiple urls that
we're going to track)

there might be multiple records within the parsefileTBL to track to a given
record within the university_urlTBL

the parsefilestatusTBL will have multiple records for each record within the
parsefileTBL that it links/joins on. this table basically provides ongoing
status for the changes made to the underlying docs within the
parsefileTBL...

the userTBL has a unique ID for each record, which is referenced within
other tables...


i'm simply trying to create a select that provides me with data from each
table, such that i can do something like:

select
p2.statusID as parsestatus,
p2.action as parseaction,
u2.name,
p1.userID,
u3.ID,
u3.url as schoolurl,
u3.urltype as urltype,
u1.name as school,
u1.city as city,
u1.stateVAL as state
from universityTBL as u1
left join university_urlTBL as u3
 on u3.universityID = u1.ID
join parsefileTBL as p1
 on p1.university_urlID=u3.ID
join parsefilestatusTBL as p2
 on p2.fileID = p1.fileID
left join userTBL as u2
 on u2.ID = p1.userID
where u3.universityID='40';

this sortof works, but the 'name' from the userTBL is listed as 'NULL'. in
fact i should have a list of '4' items, with a defined user for one of the
items, and NULL for the other 3 as no user has yet been defined!! it appears
that the information for the userID is being returned correctly, as i can
display the userID as being NULL for the items that haven't defined a user,
and the userID is set for the item where the user has been defined....

it should be doable, to create the 'select' using 'left join' statements,
and in fact i had it working, or at least i thought i did... but i somehow
screwed something up...


thanks for any help/assistance/pointers....!!!

-bruce



--
MySQL General Mailing List
For list archives: http://lists.mysql.com/mysql
To unsubscribe:    http://lists.mysql.com/[EMAIL PROTECTED]




--
MySQL General Mailing List
For list archives: http://lists.mysql.com/mysql
To unsubscribe:
http://lists.mysql.com/[EMAIL PROTECTED]




--
MySQL General Mailing List
For list archives: http://lists.mysql.com/mysql
To unsubscribe:
http://lists.mysql.com/[EMAIL PROTECTED]




-- 
MySQL General Mailing List
For list archives: http://lists.mysql.com/mysql
To unsubscribe:    http://lists.mysql.com/[EMAIL PROTECTED]

Reply via email to