admin 发表于 2023-7-16 20:04:42

discuz批量操作数据sql分享

1:批量删除回帖pre_forum_post表中存储的是论坛帖子和回复。每增加一个帖子或者回复,pid值+1.
first值为1的,代表是主题。first值为0的,代表是回帖。
delete from pre_forum_post where pid>3 and pid<16283795 and first=0;


2:批量删除用户签名
update pre_common_member_field_forum set sightml='';


3:批量删除N天前的用户短消息
DELETE FROM pre_ucenter_pm_messages_0 WHERE dateline < 1671501543 ;
时间戳可以找转换 Unix时间戳(timestamp)转换工具


4:调整某个帖子的点击数利用seo
<div><font size="3">UPDATE cdb_threads SET views=点击数 WHERE tid=主题编号; </font></div><div><font size="3">UPDATE `cdb_forums` SET `allowmediacode` = '1'</font></div>


5:一次性关闭板块fid20帖子
UPDATE `cdb_threads` SET `closed` = '1' WHERE `fid` =20 ;

6.discuz批量删除回复并且保留主题的方法,3.4版本进入后台>站长>数据库>升级需要将 config/config_global.php 当中的 $_config 设置修改为 1 才能自己随意书写 SQL 升级语句
执行下列语句即可DELETE FROM `pre_forum_post` WHERE `first` !=1 and fid='版块ID'或者
DELETE FROM `pre_forum_post` WHERE `first` !=1 and tid='帖子ID'帖子的回复楼层还在的话,在后台>工具>更新统计 点“重建用户发帖数”和“重建主题帖数” 即可解决。



页: [1]
查看完整版本: discuz批量操作数据sql分享