Jump to content

Help joining tables


Go to solution Solved by slj90,

Recommended Posts

I currently use the following query to get status's and count the number of likes from 2 different tables. However, I now want to join the user table to this query.

SELECT s.*, COUNT(l.likes_location_id) AS likeCount
 FROM stream AS s
  LEFT JOIN likes AS l ON ( l.likes_location_id = s.stream_id )
 GROUP BY s.stream_id
 ORDER BY s.stream_id DESC LIMIT 50

What do I need to add to include the 'user' table?

 

Also, could anyone recommend a good tutorial for joining tables?

Many thanks,

 

Link to comment
https://forums.phpfreaks.com/topic/293698-help-joining-tables/
Share on other sites

  • Solution

I currently use the following query to get status's and count the number of likes from 2 different tables. However, I now want to join the user table to this query.

SELECT s.*, COUNT(l.likes_location_id) AS likeCount
 FROM stream AS s
  LEFT JOIN likes AS l ON ( l.likes_location_id = s.stream_id )
 GROUP BY s.stream_id
 ORDER BY s.stream_id DESC LIMIT 50

What do I need to add to include the 'user' table?

 

Also, could anyone recommend a good tutorial for joining tables?

 

Many thanks,

Trial and error...

SELECT s.*, u.*, COUNT(l.likes_location_id) AS likeCount
 FROM stream AS s
 LEFT JOIN users as u ON (u.users_username = s.stream_username)
  LEFT JOIN likes AS l ON ( l.likes_location_id = s.stream_id )
 GROUP BY s.stream_id
 ORDER BY s.stream_id DESC LIMIT 50
Link to comment
https://forums.phpfreaks.com/topic/293698-help-joining-tables/#findComment-1501877
Share on other sites

A few things:

 

1. Don't use SELECT * unless you really need everything from those tables. Requesting all the columns takes more resources to run the query and will not scale well.

 

2. Don't use a LEFT/RIGHT JOIN unless it is necessary. Again, it uses more resources than needed. I would assume that every stream has an association with a user - if so, no LEFT JOIN would be needed to the users table.

 

3. Are you really using the username as the primary and foreign key? Normally an INT type field would be used and be indexed for performance.

Link to comment
https://forums.phpfreaks.com/topic/293698-help-joining-tables/#findComment-1501880
Share on other sites

A few things:

 

1. Don't use SELECT * unless you really need everything from those tables. Requesting all the columns takes more resources to run the query and will not scale well.

 

2. Don't use a LEFT/RIGHT JOIN unless it is necessary. Again, it uses more resources than needed. I would assume that every stream has an association with a user - if so, no LEFT JOIN would be needed to the users table.

 

3. Are you really using the username as the primary and foreign key? Normally an INT type field would be used and be indexed for performance.

 

Thanks for the reply,

 

I am using all columns in the tables except for the users table so I will change that to just get the required data.

 

How would I write it without the LEFT JOIN? I have tried it with just "JOIN" and that doesn't give any results.

 

I am using the username to make the relationship in this case but it's not the primary key in the tables. Is using it to make the relationship a problem?

 

Thanks for your help

Link to comment
https://forums.phpfreaks.com/topic/293698-help-joining-tables/#findComment-1501946
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.