Go Back   vb.org Archive > vBulletin 4 Discussion > vB4 Programming Discussions
FAQ Community Calendar Today's Posts Search

Reply
 
Thread Tools Display Modes
  #1  
Old 08-08-2013, 02:28 PM
TerryMason TerryMason is offline
 
Join Date: Oct 2005
Posts: 57
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default MySQL query to find users who don't want email

I'm looking to update the below mysql query to look at the "receive admin email" setting in vbulletin, and only select those that are set to YES.



PHP Code:
    //  Get Members
    
$members $db->query_read("
        SELECT user.email, user.userid, user.username " 
iif((!empty($vbulletin->options['c_news_letter_field'])),",userfield." $vbulletin->options['c_news_letter_field'] . "") . "
        FROM " 
TABLE_PREFIX "user AS user
        " 
iif((!empty($vbulletin->options['c_news_letter_field'])),"LEFT JOIN " TABLE_PREFIX "userfield AS userfield ON (userfield.userid = user.userid)") . "
        WHERE user.userid >= " 
$vbulletin->GPC['startat'] . "     
        " 
iif((!empty($vbulletin->options['c_news_letter_field']))," AND (userfield." $vbulletin->options[c_news_letter_field] . " = '" $vbulletin->options[c_news_letter_field_yes] . "' OR userfield." $vbulletin->options[c_news_letter_field] . " = '')") . 
        " 
iif((!empty($vbulletin->GPC['usergroups'])), "AND user.usergroupid IN ('" implode("','",$c_news_letter_filter_usergroups) . "')") . "
        ORDER BY user.userid ASC
        LIMIT " 
$vbulletin->GPC['perpage']
    ); 


I *think* it should be something like this (I added AND userfield." . $vbulletin->options['16'] . ") )

PHP Code:
        WHERE user.userid >= " . $vbulletin->GPC['startat'] . "     
        " . iif((!empty(
$vbulletin->options['c_news_letter_field']))," AND (userfield." . $vbulletin->options[c_news_letter_field] . " '" . $vbulletin->options[c_news_letter_field_yes] . "' OR userfield." . $vbulletin->options[c_news_letter_field] . " '')     AND userfield." . $vbulletin->options['16'] . ")     ") . " 
        " . iif((!empty(
$vbulletin->GPC['usergroups'])), "AND user.usergroupid IN ('" . implode("','",$c_news_letter_filter_usergroups) . "')") . "
        
ORDER BY user.userid ASC 

Does that seem right?
Reply With Quote
  #2  
Old 08-08-2013, 03:33 PM
kh99 kh99 is offline
 
Join Date: Aug 2009
Location: Maine
Posts: 13,185
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I think you want to add
Code:
AND (user.options & " . $vbulletin->bf_misc_useroptions['adminemail'] . ")

ETA: you'd also need to add user.options to the list of fields being selected.
Reply With Quote
  #3  
Old 08-08-2013, 03:59 PM
TerryMason TerryMason is offline
 
Join Date: Oct 2005
Posts: 57
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

Thanks kh99. I'm not great with mysql (it's easy to get lost with the " ' ), etc). Does this look right:


PHP Code:
    //  Get Members
    
$members $db->query_read("
        SELECT user.email, user.userid, user.username, user.options " 
iif((!empty($vbulletin->options['c_news_letter_field'])),",userfield." $vbulletin->options['c_news_letter_field'] . "") . "
        FROM " 
TABLE_PREFIX "user AS user
        " 
iif((!empty($vbulletin->options['c_news_letter_field'])),"LEFT JOIN " TABLE_PREFIX "userfield AS userfield ON (userfield.userid = user.userid)") . "
        WHERE user.userid >= " 
$vbulletin->GPC['startat'] . "     
        " 
iif((!empty($vbulletin->options['c_news_letter_field']))," AND (userfield." $vbulletin->options[c_news_letter_field] . " = '" $vbulletin->options[c_news_letter_field_yes] . "' OR userfield." $vbulletin->options[c_news_letter_field] . " = '')"   AND (user.options " . $vbulletin->bf_misc_useroptions['adminemail'] . ")  ) . 
        " 
iif((!empty($vbulletin->GPC['usergroups'])), "AND user.usergroupid IN ('" implode("','",$c_news_letter_filter_usergroups) . "')") . "
        ORDER BY user.userid ASC
        LIMIT " 
$vbulletin->GPC['perpage']
    ); 
Reply With Quote
  #4  
Old 08-08-2013, 07:46 PM
kh99 kh99 is offline
 
Join Date: Aug 2009
Location: Maine
Posts: 13,185
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I have trouble sorting out that stuff just by looking at it, but I think you have one extra double quote char before the AND you added.
Reply With Quote
  #5  
Old 09-12-2013, 06:44 PM
TerryMason TerryMason is offline
 
Join Date: Oct 2005
Posts: 57
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

I ended up getting this code to work. I can't say that I really understand it though

Code:
	//  Get Members
	$members = $db->query_read("
		SELECT user.email, user.userid, user.username, user.options " . iif((!empty($vbulletin->options['c_news_letter_field'])),",userfield." . $vbulletin->options['c_news_letter_field'] . "") . "
		FROM " . TABLE_PREFIX . "user AS user
		" . iif((!empty($vbulletin->options['c_news_letter_field'])),"LEFT JOIN " . TABLE_PREFIX . "userfield AS userfield ON (userfield.userid = user.userid)") . "
		WHERE user.userid >= " . $vbulletin->GPC['startat'] . " 	
	        " . iif((!empty($vbulletin->options['c_news_letter_field']))," AND (userfield." . $vbulletin->options[c_news_letter_field] . " = '" . $vbulletin->options[c_news_letter_field_yes] . "' OR userfield." . $vbulletin->options[c_news_letter_field] . " = '')") . "  

		" . iif(!$vbulletin->GPC['user']['adminemail'], " AND (options & " . $vbulletin->bf_misc_useroptions['adminemail'] . ")") . "

		" . iif((!empty($vbulletin->GPC['usergroups'])), "AND user.usergroupid IN ('" . implode("','",$c_news_letter_filter_usergroups) . "')") . "
		ORDER BY user.userid ASC
		LIMIT " . $vbulletin->GPC['perpage']
	);

this was the line that did the heavy lifting:

Code:
" . iif(!$vbulletin->GPC['user']['adminemail'], " AND (options & " . $vbulletin->bf_misc_useroptions['adminemail'] . ")") . "

Do you guys see any problems with this code?
Reply With Quote
Reply


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 07:32 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.03960 seconds
  • Memory Usage 2,233KB
  • 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_code
  • (3)bbcode_php
  • (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_postinfo_query
  • fetch_postinfo
  • 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