温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2021-11-06 10:51:51 来源:亿速云 阅读:208 作者:小新 栏目:MySQL数据库

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

结构:

  1. create table user_baseinfo(

  2.     userid bigint not null primary key ,

  3.     createtime timestamp

  4. );


  5. create table user_daily_log(

  6.     userid bigint,

  7.     dt date ,

  8.     somevalue int,

  9.     primary key (userid,dt)

  10. );

测试数据如下:

  1. INSERT INTO `user_baseinfo` (`userid`,`createtime`) VALUES (100,'2017-09-18 00:00:00');

  2. INSERT INTO `user_baseinfo` (`userid`,`createtime`) VALUES (200,'2017-09-23 00:00:00');


  3. INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,'2017-09-20',1);

  4. INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,'2017-09-22',3);

  5. INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,'2017-09-23',3);

  6. INSERT INTO `user_daily_log` (`userid`,`dt`,`somevalue`) VALUES (100,'2017-09-25',3);

  7. 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的用户,没有创建相关记录 。现在要补录这部分数据。

解决:

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


  1. insert into user_daily_log(userid,dt,somevalue)

  2. select t1.userid,t1.ctime,0 from (

  3.     select u.userid,u.createtime+interval (id-1) day  ctime from

  4.     user_baseinfo u inner join nums n on(datediff(now(),u.createtime)>=n.id)

  5. ) t1

  6. left join user_daily_log log on (t1.userid=log.userid and t1.ctime=log.dt)

  7. where log.userid is null;

  8. ;

感谢各位的阅读!关于“mysql中怎么用数字辅助表补录数据一则”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI