I have a table with about 150 websites listed in it with the columns “site_name”, “visible_name” (basically a formatted name), and “description.” For a given page on my site, I want to pull site_name and visible_name for every site in the table, and I want to pull all three columns for the selected site, which comes from the $_GET array (a URL parameter).
Right now I’m using 2 queries to do this, one that says “Get site_name and visible_name for all sites” and another that says “Get all 3 fields for one specific site.” I’m guess a better way to do it is:
SELECT * FROM site_list;
thus reducing to 1 query, and then doing the rest post-query, which brings up 2 questions:
- The “description” field for each site is about 200-300 characters. Is it bad from a performance standpoint to pull this for all 150 sites if I’m only using it for 1 site?
- How do I reference the specific row from the MySQL result set for the site specificed in the URL? For example, if the URL is “mysite.com/results?site_name=foo” how do I do the post-query equivalent of
SELECT * FROM site_list where site_name=foo;?
I don’t know how to get the data for “site_name=foo” without looping through the entire result array and checking to see if site_name matches the URL parameter. Isn’t there a more efficient way to do it?
Thanks,
Chris
PS: I noticed a similar question on stackoverflow and read through all the answers but it didn’t help in my situation, which is why I’m posting this.
Thanks,
Chris
I believe what you do now, keeping sperated queries for getting a list of sites with just titles and one detailed view with description for a single given site, is good. You don’t pull any unneeded data and both queries being very simple are fast.
It is possible to combine both your queries into one, using left join, something maybe like:
resulting in all sites without matching name having NULL as description, you could even sort it using
to get the site with description as first fetched row, thus eliminating need to iterate through results to find it, but mysql would have to do a lot more work to give you this result, negating any possible gain you could hope for. So basically stick to what you have now, its good.