分享更有价值
被信任是一种快乐

mysql中怎么用数字辅助表补录数据一则

文章页正文上

这篇文章给大家分享的是有关mysql中怎么用数字辅助表补录数据一则的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 结构:

create table user_baseinfo(
userid bigint not null primary key ,
createtime timestamp
);

create table user_daily_log(
userid bigint,
dt date ,
somevalue int,
primary key (userid,dt)
);测试数据如下:

INSERT INTO `user_baseinfo` (`userid`,`createtime`) VALUES (100,’2017-09-18 00:00:00′);
INSERT INTO `user_baseinfo` (`userid`,`createtime`) VALUES (200,’2017-09-23 00:00:00′);

INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,’2017-09-20′,1);
INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,’2017-09-22′,3);
INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,’2017-09-23′,3);
INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,’2017-09-25′,3);
INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (200,’2017-09-23′,1);
今天的日期 : 2017-09-26

user_baseinfo是用户基本信息表,包括用户ID和创建时间.
user_daily_log 是用户每天的统计表,要求用户自创建以来,每天都有一个统计数据,即使统计值为0,也要产生一条数据.

问题:程序有bug,很多统计值为0的用户,没有创建相关记录 。现在要补录这部分数据。

解决:

补齐相关数据

insert into user_daily_log(userid,dt,somevalue)
select t1.userid,t1.ctime,0 from (
select u.userid,u.createtime+interval (id-1) day ctime from
user_baseinfo u inner join nums n on(datediff(now免费主机域名(),u.createtime)>=n.id)
) t1
left join user_daily_log log on (t1.userid=log.userid and t1.ctime=log.dt)
where log.userid is null;
;感谢各位的阅读!关于“mysql中怎么用数字辅助表补录数据一则”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去免费主机域名让更多的人看到吧!

相关推荐: mysql中mysqldumper怎么用

这篇文章主要为大家展示了“mysql中mysqldumper怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql中mysqldumper怎么用”这篇文章吧。并行处理: 使用mydumper命令的局限在与他…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册