Jump to content

MYSQL multiple joins Needing a DISTINCT operation to happen


snowdog

Recommended Posts

Here is the sql

 

SELECT DISTINCT `m`.`ql_id`,`r`.`email` FROM `ql_master`.`ql_main` AS `m`, `cpcoaching`.`reminder_emails` AS `r`, `ql_master`.`ql_personal_data` AS `p`, `ql_master`.`[color=red]ql_reo[/color]` AS `reo` WHERE `r`.`client_id` = `m`.`ql_id` AND `r`.`client_id` = `p`.`ql_id` AND `reo`.`ql_id` = `m`.`ql_id` AND `reo`.`reo` = '1' AND `m`.`site_access` = '1' ORDER BY `r`.`client_id` ASC

 

the ql_reo in red has everybody that is in the reo program listed in the datatbase, if they work multiple states then they have more than one entry, associated with their ql_id. What I need is to pull the DISTINCT list of ql_id from the ql_reo database with the corresponding information from the other databases in the join. The join works but gives me say 200 results with multiple entries for the same ql_id. When I do a manual count it should be 88. The distinct in my code does not work the way I want it to. Any ideas? I am at a loss here. New to the whole joining thing. I can do it without the joins :)

 

 

Snowdog

Link to comment
Share on other sites

Let me repost that before I look at it:

 

SELECT DISTINCT `m`.`ql_id`,`r`.`email`
FROM `ql_master`.`ql_main` AS `m`,
`cpcoaching`.`reminder_emails` AS `r`,
`ql_master`.`ql_personal_data` AS `p`,
`ql_master`.`[color=red]ql_reo[/color]` AS `reo`
WHERE `r`.`client_id` = `m`.`ql_id`
AND `r`.`client_id` = `p`.`ql_id`
AND `reo`.`ql_id` = `m`.`ql_id`
AND `reo`.`reo` = '1'
AND `m`.`site_access` = '1'
ORDER BY `r`.`client_id` ASC

Link to comment
Share on other sites

What I mean is this (taken from mysql manual)

 

In most cases, a DISTINCT clause can be considered as a special case of GROUP BY. For example, the following two queries are equivalent:

 

SELECT DISTINCT c1, c2, c3 FROM t1

WHERE c1 > const;

 

SELECT c1, c2, c3 FROM t1

WHERE c1 > const GROUP BY c1, c2, c3;

Link to comment
Share on other sites

Is it generally better to use GROUP BY in mysql unless you really want to use DISTINCT?  That's the rule for postgres.  Because DISTINCT always sorts the rows, but GROUP BY can use a hash table (which is not part of the SQL spec, it's just the implementation).

Link to comment
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.