用數字輔助表補錄資料一則

壹頁書發表於2017-09-26
結構:

  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的使用者,沒有建立相關記錄 。現在要補錄這部分資料。

解決:

補齊相關資料



  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. ;



來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29254281/viewspace-2145456/,如需轉載,請註明出處,否則將追究法律責任。

相關文章