vb.org Archive

vb.org Archive (https://vborg.vbsupport.ru/index.php)
-   vB3 Programming Discussions (https://vborg.vbsupport.ru/forumdisplay.php?f=15)
-   -   Does this mysql code work for deleting people's PMs if they have only 1 PM? (https://vborg.vbsupport.ru/showthread.php?t=136389)

SnickersTK 01-13-2007 01:42 PM

Does this mysql code work for deleting people's PMs if they have only 1 PM?
 
been making this code and I admit that I am very new to mysql, so it might not make sense.

I haven't dared to try it out.

PHP Code:

<?php
$connection 
mysql_connect("localhost""username""password");
   
mysql_select_db("database"$connection); //connect to server and select database
   
require ("global.php"); 
$time time() - (60 24 60 60);

$userid_result query("SELECT `userid` ' 
        . ' FROM `user` ' 
        . ' WHERE `pmtotal` = 1 ' 
        . ' INTERSECT '
        . ' Select `fromuserid` ' 
        . ' FROM `pmtext` ' 
        . ' WHERE `dateline` < 
$time");
        
//Make sure that the user-ids selected with 1 total PM only gets choosen if the PM is 60 days old.  


$sql ' TRUNCATE `*` ' 
        
' FROM `pm` ' 
        
' WHERE `userid` = $userid_result';
         
$sql 'TRUNCATE `*` ' 
        
' FROM `pmtext` ' 
        
' WHERE `fromuserid` = $userid_result'
         
MySQL_query($sql) or die('MySQL Failed Because: ' mysql_error()); 

?>

Any assistance is greatly appreciated. I think it is a nice hack. I am running a giant board and all members who signs up gets an welcome PM (very popular and I don't want to get rid of it)

Tuk4 01-13-2007 02:16 PM

Well, never tried to work with PMs and stuff.
But suggestions to how i would make it, i would check the registration date - and check the message in PM date - and if 1. there for if the user have new message from another user, and he only have 1 pm, it wont delete it everytime.

Farcaster 01-15-2007 02:55 PM

It is notable that in MySQL v4.0 and on, TRUNCATE TABLE drops ALL ROWS, and does not take a WHERE clause. You also need to execute the queries and return the rows before using the results in another query. Even then, you are going to need to use explode to put them into a comma delimited string that you can use in the WHERE clause with IN. The easiest thing to do would probably be to execute a query to get all of the PMs you want to delete and then iterate through them and delete them using the PM datamanager. If you do it manually, you need to: 1) update the user table with the new post count, 2) delete the references in PM, and 3) delete the pm text from the pmtext table, BUT only if no other pm is referencing the same textid.

Attilitus 01-17-2007 12:03 AM

Quote:

Originally Posted by Farcaster (Post 1159873)
It is notable that in MySQL v4.0 and on, TRUNCATE TABLE drops ALL ROWS, and does not take a WHERE clause. You also need to execute the queries and return the rows before using the results in another query. Even then, you are going to need to use explode to put them into a comma delimited string that you can use in the WHERE clause with IN. The easiest thing to do would probably be to execute a query to get all of the PMs you want to delete and then iterate through them and delete them using the PM datamanager. If you do it manually, you need to: 1) update the user table with the new post count, 2) delete the references in PM, and 3) delete the pm text from the pmtext table, BUT only if no other pm is referencing the same textid.

Ha ha... quoted for Notability.

Dismounted 01-17-2007 02:19 AM

And the ' . 's aren't needed.


All times are GMT. The time now is 11:35 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.01192 seconds
  • Memory Usage 1,730KB
  • Queries Executed 10 (?)
More Information
Template Usage:
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)bbcode_php_printable
  • (1)bbcode_quote_printable
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_navbar_search
  • (1)printthread
  • (5)printthreadbit
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • showthread
Included Files:
  • ./printthread.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/class_bbcode_alt.php
  • ./includes/class_bbcode.php
  • ./includes/functions_bigthree.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
  • printthread_start
  • bbcode_fetch_tags
  • bbcode_create
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • printthread_post
  • printthread_complete