Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

MySQL Distinct question

Posted on 2012-04-04
10
437 Views
Last Modified: 2012-04-05
I have a question about the "distinct" syntax.

In this example:
Select distinct pID, name, address, phone, email from table;

Open in new window


I only want the distinct pID.

In this query, would my results show distinct values for pID, name, address, phone, and email or JUST pID?
0
Comment
Question by:lvollmer
  • 5
  • 3
  • 2
10 Comments
 
LVL 18

Expert Comment

by:lludden
ID: 37807874
That query will show all of the distinct rows between all values listed.

If you want to just see the unique PID, you need to just have the columns that you want to be distinct in the select.  If you need to join it back to the source table, you can make it a derived table and join it.
0
 

Author Comment

by:lvollmer
ID: 37807890
Here is my real life query:
SELECT
    pd.person_id, pd.first,pd.email,sod.option_text
FROM
    pd
INNER JOIN
    srf ON pd.person_key = srf.person_key
INNER JOIN
    ON srf.survey_option_key =  sod.survey_option_key
WHERE
    srf.survey_option_key IN (297,298,299)
AND
    srf.survey_question_key = '43'
AND
    pd.is_subscriber ='1'
ORDER BY
    pd.person_id ASC

Open in new window


This works fine, except that it returns rows multiple times for pd.person_id. I am not sure how to apply what you suggested to make sure ONLY pd.person_id is distinct. Any idea?
0
 
LVL 18

Expert Comment

by:lludden
ID: 37808111
This will do an inner join to just the distinct ID list so they only display once.
SELECT
    pd.person_id, pd.first,pd.email,sod.option_text
FROM
    pd
INNER JOIN
    srf ON pd.person_key = srf.person_key
INNER JOIN
    ON srf.survey_option_key =  sod.survey_option_key
INNER JOIN (SELECT DISTINCT Person_id FROM PD) PDList ON pd.Person_ID = PDList.Person_id
WHERE
    srf.survey_option_key IN (297,298,299)
AND
    srf.survey_question_key = '43'
AND
    pd.is_subscriber ='1'
ORDER BY
    pd.person_id ASC

Open in new window

0
Master Your Team's Linux and Cloud Stack

Come see why top tech companies like Mailchimp and Media Temple use Linux Academy to build their employee training programs.

 

Author Comment

by:lvollmer
ID: 37808164
thanks - it is running, so i will report back when finished.
0
 
LVL 16

Expert Comment

by:theo kouwenhoven
ID: 37810269
Hi lvollmer,

Isn't this enough:

Select  pID, name, address, phone, email from table group by pID, name, address, phone, email
0
 

Author Comment

by:lvollmer
ID: 37811612
Murphey - woudln't that still show multiple rows for one pID?
0
 
LVL 16

Accepted Solution

by:
theo kouwenhoven earned 500 total points
ID: 37811716
Assuming that pID = PersonalID
and looking to your select, the combination pID and name  etc will be unique,

If not, it makes no sence to select an pID with a name that (maybe) not belongs to that pID or
is one of many that belongs to that pID.

So if pID is connected to one person, the answer is NO

if a pID is connected to more then one person, the answer is Yes, but is that out put still reliable?
0
 

Author Comment

by:lvollmer
ID: 37811822
I will run it now and test.

In the real query I am running (see second query) the result set will return multiple rows for pd.person_id if they have values for this:

WHERE
    srf.survey_option_key IN (297,298,299)
0
 

Author Comment

by:lvollmer
ID: 37812785
this worked, thank you. I guess I did not understand how GROUP BY worked, and it is perfect for this instance.
0
 
LVL 16

Expert Comment

by:theo kouwenhoven
ID: 37814123
GROUP BY wil select each record that has a unique group by,
if your tabel contains 2 rows with the same pID for 1 person with 2 adresses, the line is shown twice
0

Featured Post

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I annotated my article on ransomware somewhat extensively, but I keep adding new references and wanted to put a link to the reference library.  Despite all the reference tools I have on hand, it was not easy to find a way to do this easily. I finall…
Never store passwords in plain text or just their hash: it seems a no-brainier, but there are still plenty of people doing that. I present the why and how on this subject, offering my own real life solution that you can implement right away, bringin…
Video by: Steve
Using examples as well as descriptions, step through each of the common simple join types, explaining differences in syntax, differences in expected outputs and showing how the queries run along with the actual outputs based upon a simple set of dem…
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…

856 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question