Go Back   vb.org Archive > vBulletin 3 Discussion > vB3 Programming Discussions
  #1  
Old 07-04-2005, 04:10 AM
Cloudrunner's Avatar
Cloudrunner Cloudrunner is offline
 
Join Date: May 2003
Location: Butte, MT
Posts: 635
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default I suck at MySQL JOINS, can someone gimme a hand?

How would I compress these four queries into one?
PHP Code:
$nav_new_users_today $vbulletin->db->query_first("SELECT
    COUNT(*) AS count
    FROM "
.TABLE_PREFIX."user
    WHERE joindate >= '"
.$nav_starttime."'");
$nav_users $vbulletin->db->query_first("SELECT
    COUNT(*) AS count
    FROM "
.TABLE_PREFIX."user
    WHERE lastactivity >= '"
.$nav_starttime."'");
$nav_new_threads $vbulletin->db->query_first("SELECT
    COUNT(*) AS count
    FROM "
.TABLE_PREFIX."thread
    WHERE dateline >= '"
.$vbulletin->userinfo['lastvisit']."'");
$nav_new_posts $vbulletin->db->query_first("SELECT
    COUNT(*) AS count
    FROM "
.TABLE_PREFIX."post
    WHERE dateline >= '"
.$vbulletin->userinfo['lastvisit']."'"); 
I came up with a LEFT JOIN scenario, but alas, due to my lack of knowledge on this, it failed...
PHP Code:
$nav_query $vbulletin->db->query_first("SELECT 
    COUNT(new_user.*) AS new_users_today, 
    COUNT(thread.*) AS new_threads, 
    COUNT(post.*) AS new_posts, 
    COUNT(user.*) AS users 
    FROM "
.TABLE_PREFIX."user AS new_user 
    LEFT JOIN "
.TABLE_PREFIX."thread AS thread ON(thread.dateline >= '".$vbulletin->userinfo['lastvisit']."') 
    LEFT JOIN "
.TABLE_PREFIX."post AS post ON(post.dateline >= '".$vbulletin->userinfo['lastvisit']."') 
    LEFT JOIN "
.TABLE_PREFIX."user AS user ON(user.lastactivity >= '".$nav_starttime."') 
    WHERE new_user.joindate >= '"
.$nav_starttime."'"); 
Any and all help on this would be greatly appreciated...I'm just straight up stuck, I've been through all of my reference materials, but just cannot figure out how to do this...

Thank you in advance for the assistance!

)O( Cloudrunner )O(
Reply With Quote
  #2  
Old 07-04-2005, 04:32 AM
filburt1 filburt1 is offline
 
Join Date: Feb 2002
Location: Maryland, US
Posts: 6,144
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Can you explain in English what specifically you are you trying to do (i.e., what data you are trying to retrieve)?
Reply With Quote
  #3  
Old 07-04-2005, 04:37 AM
Cloudrunner's Avatar
Cloudrunner Cloudrunner is offline
 
Join Date: May 2003
Location: Butte, MT
Posts: 635
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Quote:
Originally Posted by filburt1
Can you explain in English what specifically you are you trying to do (i.e., what data you are trying to retrieve)?
Oh that part's easy LOL

I'm looking for the total count of new users registered today, the total count of users visited, the total count of new threads since a users last visit, and the total count of new posts since a user's last visit all in one shot.

I can do that easily with the first four queries, but I want to squish those four queries into one to cus everyone and their dog here gripes about multiple queries in a hack, so I figured if I could turn those four queries into one, no one could gripe
Reply With Quote
  #4  
Old 07-04-2005, 07:17 AM
Marco van Herwaarden Marco van Herwaarden is offline
 
Join Date: Jul 2004
Posts: 25,415
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

You can not combine counts from different types of data into 1 query i think.
Reply With Quote
  #5  
Old 07-04-2005, 07:41 AM
deathemperor's Avatar
deathemperor deathemperor is offline
 
Join Date: Jul 2003
Location: HOL
Posts: 1,270
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I dont think this is right:

PHP Code:
ON(thread.dateline >= '".$vbulletin->userinfo['lastvisit']."'
ON() is used for the connection between 2 tables, not for condition IIRC.

I learnt SQL half a year ago and almost forgot complex parts +_+
Reply With Quote
Reply

Thread Tools
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT. The time now is 10:14 PM.


Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions Inc.
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.03557 seconds
  • Memory Usage 2,206KB
  • Queries Executed 13 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)ad_showthread_beforeqr
  • (1)ad_showthread_firstpost
  • (1)ad_showthread_firstpost_sig
  • (1)ad_showthread_firstpost_start
  • (3)bbcode_php
  • (1)bbcode_quote
  • (1)footer
  • (1)forumjump
  • (1)forumrules
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (1)navbar
  • (3)navbar_link
  • (120)option
  • (5)post_thanks_box
  • (5)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (5)post_thanks_postbit_info
  • (5)postbit
  • (5)postbit_onlinestatus
  • (5)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open
  • (1)tagbit_wrapper 

Phrase Groups Available:
  • global
  • inlinemod
  • postbit
  • posting
  • reputationlevel
  • showthread
Included Files:
  • ./showthread.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showthread_start
  • showthread_getinfo
  • forumjump
  • showthread_post_start
  • showthread_query_postids
  • showthread_query
  • bbcode_fetch_tags
  • bbcode_create
  • showthread_postbit_create
  • postbit_factory
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • tag_fetchbit_complete
  • forumrules
  • navbits
  • navbits_complete
  • showthread_complete