您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)mysql中怎么用數(shù)字輔助表補(bǔ)錄數(shù)據(jù)一則的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
結(jié)構(gòu):
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)
);
測試數(shù)據(jù)如下:
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和創(chuàng)建時(shí)間.
user_daily_log 是用戶每天的統(tǒng)計(jì)表,要求用戶自創(chuàng)建以來,每天都有一個(gè)統(tǒng)計(jì)數(shù)據(jù),即使統(tǒng)計(jì)值為0,也要產(chǎn)生一條數(shù)據(jù).
問題:程序有bug,很多統(tǒng)計(jì)值為0的用戶,沒有創(chuàng)建相關(guān)記錄 ?,F(xiàn)在要補(bǔ)錄這部分?jǐn)?shù)據(jù)。
解決:
補(bǔ)齊相關(guān)數(shù)據(jù)
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;
;
感謝各位的閱讀!關(guān)于“mysql中怎么用數(shù)字輔助表補(bǔ)錄數(shù)據(jù)一則”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。