问题描述
我试图修改这个 function:
// automatically delete users after 7 days in wordpress
function wcs_auto_delete_users() {
global $wpdb;
$query = $wpdb->prepare( "SELECT ID FROM $wpdb->users WHERE datediff( now(), user_registered ) > 7" );
if ( $oldUsers = $wpdb->get_results( $query, ARRAY_N ) ) {
foreach ( $oldUsers as $user_id ) {
wp_delete_user( $user_id[0] );
}
}
}
add_action( 'wcs_daily_clean_database', 'wcs_auto_delete_users' );
wp_schedule_event( time(), 'daily', 'wcs_daily_clean_database' );
以不同的方式工作 – 我想要它自动删除在 2 个月内没有活动的用户。我有一个跟踪用户活动并将数据存储在 wp_usermeta 中的插件。例:
user_id = 2; meta_key = wp_wp_kc_last_active_time; meta_value = 1422796627
这是我提出的查询:
SELECT user_id FROM wp_usermeta WHERE meta_key = 'wp_wp_kc_last_active_time' AND TIMESTAMPDIFF( second, now(), TIMESTAMP(SELECT meta_value) ) > 5184000
但是它没有选择正确的 ID 。我应该改变什么才能使其工作?
最佳解决方案
您的查询错误,因为 TIMESTAMPDIFF 的第三个参数不正确。
您应该使用 meta_value 而不是 SELECT meta_value 。
SELECT user_id FROM wp_usermeta WHERE meta_key = 'wp_wp_kc_last_active_time' AND TIMESTAMPDIFF( second, now(), TIMESTAMP(meta_value) ) > 5184000;
尝试,看看结果是否开始正确。
我刚刚检查了 mySQL Date Function Docs,你似乎做错了。
尝试以下代替:
SELECT user_id FROM wp_usermeta WHERE meta_key = 'wp_wp_kc_last_active_time' AND TIMESTAMPDIFF( MONTH, NOW(), FROM_UNIXTIME(meta_value) ) > 2;
或者可能…
global $wpdb;
$query = <<<SQL
SELECT user_id
FROM {$wpdb->usermeta}
WHERE
meta_key = 'wp_wp_kc_last_active_time'
AND DATEDIFF( NOW(), FROM_UNIXTIME( meta_value ) ) > 60
SQL;
$query = $wpdb->prepare( $query );
哪个应该收集合适的用户。如果没有,请尝试没有 datediff 声明,看看是否有任何东西返回。如果没有,那么与 meta_key 有什么不同 (例如,它真的是 wp_wp _… 或只是 wp_kc _…)
参考文献
注:本文内容整合自 Google/Baidu/Bing 辅助翻译的英文资料结果。如果您对结果不满意,可以加入我们改善翻译效果:薇晓朵技术论坛。