Solved

How do you omit duplicate entries from the list created in php?

Posted on 2008-06-21
3
583 Views
Last Modified: 2013-12-12
Hi,
I have got some PHP code that populates a list based on entries found within a MySQL database.
It is successfully creating the list, but I was wondering how to omit the duplicate entries.
I would also like them listed alphabetically.
Eventually users will select from the values available, so duplicates are not meant to be there and setting it up alphabetically is user friendly.
Thanks..the code is attached.!
-------------------------

Populating a list box

-------------------------

 

<?php

include("Settings.php"); //Path to Settings.php

 

$sql= "SELECT * FROM event";

 

$result = mysql_query($sql) or die("Sql Query Failed: " . mysql_error());
 

 

$ListOptions = "";

 

while ($row = mysql_fetch_array($result)) {

        //The following line creates the <option></option> tags for the <select> list

        $ListOptions .= "\t<option value='" . $row["ID"] . "'>" . $row["EventType"] . "</option>\n";

}

 

?>

 

<select name='MyList'>

<option value="0" selected>Select EventType</option>

<?php echo $ListOptions; ?>

</select>

Open in new window

0
Comment
Question by:Amanda Watson
  • 2
3 Comments
 
LVL 14

Expert Comment

by:agriesser
ID: 21839955
To sort them alphabetically, change your SQL statement from 'SELECT * from event' to 'SELECT * from event ORDER BY EventType' f.ex.

To avoid having duplicate entries in the database I'd suggest to create a primary key or unique column in the database itself. That way, no duplicate entries can be written to the database as a primary key or a column marked as unique assures that there are no duplicate values in it.

If you already have duplicate values in it and want to show possible duplicate values only once, you can use:

SELECT * from event GROUP BY EventType ORDER BY EventType

That way you will only get unique entries reported.

You might even want to change the primary key from ID (what it is probably at the moment) to EventType, therefore it's impossible to add duplicate entries into this table.

0
 
LVL 11

Author Comment

by:Amanda Watson
ID: 21840072
Thanks, that great.
Thanks for your help!
0
 
LVL 14

Accepted Solution

by:
agriesser earned 125 total points
ID: 21840120
You're welcome.
Will try to answer your other question too in a few minutes, please don't forget to assign points if the solution is acceptable for you.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
mysqli 3 22
Calculating number of days between two dates 7 32
How do I put a session for a radio button? 4 14
How do I change the from header when sending a mail 1 18
Build an array called $myWeek which will hold the array elements Today, Yesterday and then builds up the rest of the week by the name of the day going back 1 week.   (CODE) (CODE) Then you just need to pass your date to the function. If i…
Password hashing is better than message digests or encryption, and you should be using it instead of message digests or encryption.  Find out why and how in this article, which supplements the original article on PHP Client Registration, Login, Logo…
The viewer will learn how to look for a specific file type in a local or remote server directory using PHP.
The viewer will learn how to create a basic form using some HTML5 and PHP for later processing. Set up your basic HTML file. Open your form tag and set the method and action attributes.: (CODE) Set up your first few inputs one for the name and …

895 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

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now