Results 1 to 2 of 2
Aug 2, 2001, 16:43 #1
Counting the number of rows in a specfic table when selecting from more than one.
Lengthy topic name. I'll try to keep it as simple as possible.
I'm making a pretty basic forum program and would like to display the forum names and the number of threads in that specific forum with one query.
Normally to get the number of threads I would do
SELECT COUNT(*) FROM ef_threads WHERE forum='ForumID'
But as I need to select the name of the forum from a sepperate table it obviously means the count doesn't work. I've tried COUNT(ef_threads.*) and other variations but it doesn't work. Any suggestions on the following query to get what I'm after would be most appreciated.
SELECT ef_forums.name AS ForumName, ef_forums.id AS ForumID, count(ef_threads.*) AS ThreadCount FROM ef_forums, ef_threads WHERE ef.threads.parentforum='ForumID'
Thanks in advance. And sorry for the complexity of my explanation. I never seem able to phrase my questions in an easy and concise way. Hopefully you can understand what I mean.
Aug 2, 2001, 16:49 #2
- Join Date
- Jan 2001
- Cumberland, RI, US
- 0 Post(s)
- 0 Thread(s)
Although the above would be possible, it is MUCH faster to store the total number of threads in a value in the forum table. Performing many COUNT(*) queries on large tables will seriously bog down MySQL.