视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
按照用户ID进行分组,保留用户的最新的1000条数据,超过1000条的都
2020-11-09 16:13:16 责编:小采
文档


数据库字段:id,user_id,date,...其他若干字段 MySQL BEGIN#Routine body goes here.../*查询用户超过1000条则进行删除功能 */DECLARE act_friends_user_id INT;DECLARE act_friends_min_id INT;DECLARE dn INT default 0;/*定义查询语句*/DECLARE act CURSOR

数据库字段:id,user_id,date,...其他若干字段 MySQL $velocityCount-->
BEGIN
	#Routine body goes here...
	/*
	查询用户超过1000条则进行删除功能
	 */
	DECLARE act_friends_user_id INT;
	DECLARE act_friends_min_id INT;
	DECLARE dn INT default 0;
	/*定义查询语句*/
	DECLARE act CURSOR FOR SELECT user_id FROM act_friends GROUP BY user_id HAVING COUNT(user_id) > 1000; 
	DECLARE EXIT HANDLER FOR NOT FOUND set dn=1;
	/*开始进行循环*/
	OPEN act;
	act_loop:LOOP
	FETCH act INTO act_friends_user_id;
	/*循环到最后查找不到条件则跳出这个游标循环*/
	if dn=1 THEN
	LEAVE act_loop;
	END if;
	/*获取最新1000条数据中的最小ID值*/
	select min(id) into act_friends_min_id from (select id from act_friends where user_id =act_friends_user_id ORDER BY date DESC limit 1000) as temp;
	SELECT act_friends_min_id;
	DELETE FROM act_friends where user_id = act_friends_user_id AND id < act_friends_min_id;
	END LOOP;
	CLOSE act;
END

下载本文
显示全文
专题