mysql函数实例-统计日新增用户

本文介绍了一个用于统计新增用户的数据库函数实现。该函数通过查询前一天创建的用户记录,并将相关信息插入到详细统计数据表中,同时计算并记录日新增用户总数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

新增用户统计,仅用作备忘。

 

CREATE FUNCTION `statics_user_new`() RETURNS int(11)
    COMMENT '统计新增用户'
BEGIN
	#Routine body goes here...	
	DECLARE stopFlag INT DEFAULT 0 ;
	DECLARE _shop_id VARCHAR(11) DEFAULT NULL;	#餐厅id
	DECLARE _device VARCHAR(50) DEFAULT NULL;	#手机设备号
	DECLARE _a_token CHAR(64) DEFAULT NULL;		#与苹果服务器会话
	DECLARE _s_token VARCHAR(64) DEFAULT NULL;	#与点菜网服务器会话
	DECLARE _counts INT DEFAULT 0;
	
	#查询昨天新创建的用户
	DECLARE cur1 CURSOR FOR SELECT id, device, a_token, s_token FROM visitor_user 
		where DATE_FORMAT(create_time, '%Y-%m-%d') = DATE_SUB(DATE_FORMAT(now(),'%Y-%m-%d'), INTERVAL 1 DAY);
	DECLARE CONTINUE HANDLER FOR NOT FOUND SET stopFlag=1;
	
	OPEN cur1;
		
	FETCH cur1 INTO _shop_id, _device, _a_token, _s_token;
	WHILE  stopFlag = 0 do
		INSERT INTO report_user_new_day_detail(id, shop_id, device, a_token, s_token) 
			values (UUID(), _shop_id, _device, _a_token, _s_token);

		FETCH cur1 INTO _shop_id, _device, _a_token, _s_token;
	END WHILE;
	
	CLOSE cur1;

	#统计日新增用户数
	SELECT COUNT(device) INTO _counts FROM visitor_user 
		where DATE_FORMAT(create_time, '%Y-%m-%d') = DATE_SUB(DATE_FORMAT(now(),'%Y-%m-%d'), INTERVAL 1 DAY);
	
	INSERT INTO report_user_new_day(id, day_time, new_counts, type_client) 
		VALUES(UUID(), DATE_SUB(DATE_FORMAT(now(),'%Y-%m-%d'), INTERVAL 1 DAY), _counts, 0);
	
	SET _counts = 1;
	RETURN _counts;

END

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值