เดฑเดฟเดฒเตเดทเดฃเตฝ เดกเดพเดฑเตเดฑเดพเดฌเตเดธเตเดเดณเดฟเดฒเตเดเตเดเต เดกเดพเดฑเตเดฑ เดเดเตโเดธเตโเดเตเดฐเดพเดเตเดฑเตเดฑเตเดเตเดฏเตเดฏเตเดจเตเดจเดคเดฟเดจเตเด เดฐเตเดชเดพเดจเตเดคเดฐเดชเตเดชเตเดเตเดคเตเดคเตเดจเตเดจเดคเดฟเดจเตเด เดฒเตเดกเตเดเตเดฏเตเดฏเตเดจเตเดจเดคเดฟเดจเตเดฎเตเดณเตเดณ เดฆเดฟเดจเดเดฐเตเดฏเดเตพ เดธเตเดทเตโเดเดฟเดเตเดเดพเตป เดชเดฒเดฐเตเด เดชเตเดฐเดคเตเดฏเตเด เดเดชเดเดฐเดฃเดเตเดเตพ เดเดชเดฏเตเดเดฟเดเตเดเตเดจเตเดจเต. เดเดชเดเดฐเดฃเดเตเดเดณเตเดเต เดชเตเดฐเดเตเดฐเดฟเดฏ เดฒเตเดเต เดเตเดฏเตเดคเต, เดชเดฟเดถเดเตเดเตพ เดฐเตเดเดชเตเดชเตเดเตเดคเตเดคเตเดจเตเดจเต.
เดเดฐเต เดชเดฟเดถเดเต เดธเดเดญเดตเดฟเดเตเดเดพเตฝ, เดเดพเดธเตโเดเต เดชเตเตผเดคเตเดคเดฟเดฏเดพเดเตเดเตเดจเตเดจเดคเดฟเตฝ เดเดชเดเดฐเดฃเด เดชเดฐเดพเดเดฏเดชเตเดชเตเดเตเดเตเดตเตเดจเตเดจเตเด เดเดคเต เดฎเตเดกเตเดฏเตเดณเตเดเตพ (เดชเดฒเดชเตเดชเตเดดเตเด เดเดพเดต) เดเดตเดฟเดเต เดจเดฟเตผเดคเตเดคเดฟเดฏเตเดจเตเดจเตเด เดเดณเตเดณ เดตเดฟเดตเดฐเดเตเดเตพ เดฒเตเดเดฟเตฝ เด เดเดเตเดเดฟเดฏเดฟเดฐเดฟเดเตเดเตเดจเตเดจเต. เด เดตเดธเดพเดจ เดตเดฐเดฟเดเดณเดฟเตฝ เดชเดเตเดเดฟเดเดฏเตเดเต เดคเดจเดคเต เดเตเดฏเตเดเต เดฒเดเดเดจเด เดชเตเดฒเตเดณเตเดณ เดเดฐเต เดกเดพเดฑเตเดฑเดพเดฌเตเดธเต เดชเดฟเดถเดเต เด เดเดเตเดเดฟเดฏเดฟเดฐเดฟเดเตเดเดพเด.
ETL เดชเดฟเดถเดเต เดตเดฟเดตเดฐเดเตเดเตพ เดเดจเตเดคเต เดชเดเตเดเดพเดฃเต เดตเดนเดฟเดเตเดเตเดจเตเดจเดคเต เดเดจเตเดจ เดเตเดฆเตเดฏเดคเตเดคเดฟเดจเต เดเดคเตเดคเดฐเด เดจเตฝเดเดพเตป, เดเดดเดฟเดเตเด เดฐเดฃเตเดเต เดตเตผเดทเดฎเดพเดฏเดฟ เดธเดเดญเดตเดฟเดเตเด เดเดฒเตเดฒเดพ เดชเตเดฐเดถเตเดจเดเตเดเดณเตเด เดเดฐเต เดตเดฒเดฟเดฏ เดถเตเดเดฐเดคเตเดคเดฟเตฝ เดเดพเตป เดคเดฐเดเดคเดฟเดฐเดฟเดเตเดเต.
เดกเดพเดฑเตเดฑเดพเดฌเตเดธเต เดชเดฟเดถเดเตเดเดณเดฟเตฝ เดเดจเดฟเดชเตเดชเดฑเดฏเตเดจเตเดจเดต เดเตพเดชเตเดชเตเดเตเดจเตเดจเต: เดเดตเดถเตเดฏเดคเตเดคเดฟเดจเต เดเดเดฎเดฟเดฒเตเดฒเดพเดฏเดฟเดฐเตเดจเตเดจเต, เดเดฃเดเตเดทเตป เดจเดทเตเดเดชเตเดชเตเดเตเดเต, เดธเตเดทเตป เดนเดพเดเดเต, เดฎเตเดคเดฒเดพเดฏเดต.
เดเตเดฌเดฟเตพ เดเตเดเดณเตเดเต เดฒเดเดเดจเดเตเดเตพ, เด
เดธเดพเดงเตเดตเดพเดฏ เดเดฌเตโเดเดเตโเดฑเตเดฑเตเดเตพ, เดเดฌเตโเดเดเตโเดฑเตเดฑเตเดเดณเดฟเดฒเตเดเตเดเตเดณเตเดณ เดเดเตโเดธเดธเดฟเดจเตเดฑเต เด
เดญเดพเดตเด เดคเตเดเดเตเดเดฟเดฏเดต เดฒเตเดเดฟเดเตเดเตฝ เดชเดฟเดถเดเตเดเดณเดฟเตฝ เดเตพเดชเตเดชเตเดเตเดจเตเดจเต.
เดทเตเดกเตเดฏเตเดณเตผ เดเตเดคเตเดฏเดธเดฎเดฏเดคเตเดคเต เดธเดฎเดพเดฐเดเดญเดฟเดเตเดเตเดเตเดเดฟเดฒเตเดฒ, เดฎเดฐเดตเดฟเดชเตเดชเดฟเดเตเดเตเดเตเดเดพเด, เดฎเตเดคเดฒเดพเดฏเดต.
เดฒเดณเดฟเดคเดฎเดพเดฏ เดคเตเดฑเตเดฑเตเดเตพ เดคเดฟเดฐเตเดคเตเดคเดพเตป เดเตเดเตเดคเตฝ เดธเดฎเดฏเด เดเดเตเดเตเดเตเดจเตเดจเดฟเดฒเตเดฒ. เดเดฐเต เดจเดฒเตเดฒ ETL-เดจเต เด เดตเดฏเดฟเตฝ เดฎเดฟเดเตเดเดคเตเด เดธเตเดตเดจเตเดคเดฎเดพเดฏเดฟ เดเตเดเดพเดฐเตเดฏเด เดเตเดฏเตเดฏเดพเตป เดเดดเดฟเดฏเตเด.
เดธเดเตเดเตเตผเดฃเตเดฃเดฎเดพเดฏ เดชเดฟเดถเดเตเดเตพ เดกเดพเดฑเตเดฑ เดเตเดเดพเดฐเตเดฏเด เดเตเดฏเตเดฏเตเดจเตเดจเดคเดฟเดจเตเดณเตเดณ เดจเดเดชเดเดฟเดเตเดฐเดฎเดเตเดเตพ เดคเตเดฑเดเตเดเตเดเดฏเตเด เดชเดฐเดฟเดถเตเดงเดฟเดเตเดเตเดเดฏเตเด เดกเดพเดฑเตเดฑ เดเดฑเดตเดฟเดเดเตเดเตพ เด เดจเตเดตเตเดทเดฟเดเตเดเตเดเดฏเตเด เดเตเดฏเตเดฏเตเดฃเตเดเดคเต เดเดตเดถเตเดฏเดฎเดพเดฃเต. เดชเดฒเดชเตเดชเตเดดเตเด เดฎเดพเดฑเตเดฑเดเตเดเตพ เดชเดฐเดฟเดถเตเดงเดฟเดเตเดเตเดเดฏเตเด เดตเดฟเดจเตเดฏเดธเดฟเดเตเดเตเดเดฏเตเด เดเตเดฏเตเดฏเตเดฃเตเดเดคเดฟเดจเตเดฑเต เดเดตเดถเตเดฏเดเดคเดฏเดฟเดฒเตเดเตเดเต เดจเดฏเดฟเดเตเดเตเดจเตเดจเต.
เด
เดคเดฟเดจเดพเตฝ, เดเดฒเตเดฒเดพ เดชเตเดฐเดถเตเดจเดเตเดเดณเดฟเดฒเตเด เดชเดเตเดคเดฟเดฏเตเด เดกเดพเดฑเตเดฑเดพเดฌเตเดธเตเดฎเดพเดฏเดฟ เดฌเดจเตเดงเดชเตเดชเตเดเตเดเดคเดพเดฃเต. เดเดฒเตเดฒเดพ เดชเดฟเดถเดเตเดเดณเตเดเตเดฏเตเด 48% เดฒเดณเดฟเดคเดฎเดพเดฏ เดชเดฟเดถเดเตเดเดณเดพเดฃเต.
เดเดฒเตเดฒเดพ เดชเตเดฐเดถเตโเดจเดเตเดเดณเตเดเตเดฏเตเด เดฎเตเดจเตเดจเดฟเดฒเตเดจเตเดจเต เดธเตเดฑเตเดฑเตเดฑเตเดเต เดฒเตเดเดฟเดเตเดเดฟเดฒเตเดฏเต เดฎเตเดกเดฒเดฟเดฒเตเดฏเต เดฎเดพเดฑเตเดฑเดเตเดเดณเตเดฎเดพเดฏเดฟ เดฌเดจเตเดงเดชเตเดชเตเดเตเดเดคเดพเดฃเต; เดเดคเดฟเตฝ เดชเดเตเดคเดฟเดฏเดฟเดฒเดงเดฟเดเด เดชเดฟเดถเดเตเดเดณเตเด เดธเดเตเดเตเตผเดฃเตเดฃเดฎเดพเดฃเต.
เดเดฒเตเดฒเดพ เดชเตเดฐเดถเตโเดจเดเตเดเดณเดฟเดฒเตเด เดจเดพเดฒเดฟเดฒเตเดจเตเดจเดฟเตฝ เดคเดพเดดเต เดฎเดพเดคเตเดฐเด เดเดพเดธเตโเดเต เดทเตเดกเตเดฏเตเดณเดฑเตเดฎเดพเดฏเดฟ เดฌเดจเตเดงเดชเตเดชเตเดเตเดเดคเดพเดฃเต, เด เดคเดฟเตฝ 18% เดฒเดณเดฟเดคเดฎเดพเดฏ เดชเดฟเดถเดเตเดเดณเดพเดฃเต.
เดฎเตเดคเตเดคเดคเตเดคเดฟเตฝ, เดธเดเดญเดตเดฟเดเตเดเตเดจเตเดจ เดเดฒเตเดฒเดพ เดชเดฟเดถเดเตเดเดณเตเดเตเดฏเตเด 22% เดธเดเตเดเตเตผเดฃเตเดฃเดตเตเด เดคเดฟเดฐเตเดคเตเดคเดพเตป เดเดฑเตเดฑเดตเตเด เดถเตเดฐเดฆเตเดงเดฏเตเด เดธเดฎเดฏเดตเตเด เดเดตเดถเตเดฏเดฎเดพเดฃเต. เด เดต เดเดดเตเดเดฏเดฟเตฝ เดเดฐเดฟเดเตเดเตฝ เดธเดเดญเดตเดฟเดเตเดเตเดจเตเดจเต. เดฒเดณเดฟเดคเดฎเดพเดฏ เดคเตเดฑเตเดฑเตเดเตพ เดฎเดฟเดเตเดเดตเดพเดฑเตเด เดเดฒเตเดฒเดพ เดฆเดฟเดตเดธเดตเตเด เดธเดเดญเดตเดฟเดเตเดเตเดฎเตเดชเตเตพ.
เดตเตเดฏเดเตเดคเดฎเดพเดฏเตเด, เดฒเตเดเดฟเตฝ เดชเดฟเดถเดเดฟเดจเตเดฑเต เดธเตเดฅเดพเดจเด เดเดดเดฟเดฏเตเดจเตเดจเดคเตเดฐ เดเตเดคเตเดฏเดฎเดพเดฏเดฟ เดธเตเดเดฟเดชเตเดชเดฟเดเตเดเตเดฎเตเดชเตเตพ ETL เดชเตเดฐเดเตเดฐเดฟเดฏเดเตพ เดจเดฟเดฐเตเดเตเดทเดฟเดเตเดเตเดจเตเดจเดคเต เดซเดฒเดชเตเดฐเดฆเดฎเดพเดเตเด, เดเตเดเดพเดคเต เดชเตเดฐเดถเตเดจเดคเตเดคเดฟเดจเตเดฑเต เดเดฑเดตเดฟเดเด เดเดฃเตเดเตเดคเตเดคเดพเตป เดเตเดฑเดเตเด เดธเดฎเดฏเด เดเดตเดถเตเดฏเดฎเดพเดฃเต.
เดซเดฒเดชเตเดฐเดฆเดฎเดพเดฏ เดจเดฟเดฐเตเดเตเดทเดฃเด
ETL เดฎเตเดฃเดฟเดฑเตเดฑเดฑเดฟเดเดเต เดชเตเดฐเดเตเดฐเดฟเดฏเดฏเดฟเตฝ เดเดพเตป เดเดจเตเดคเดพเดฃเต เดเดพเดฃเดพเตป เดเดเตเดฐเดนเดฟเดเตเดเดคเต?
เดเดฐเดเดญเดฟเดเตเดเตเด - เดเดพเตป เดเตเดฒเดฟ เดเตเดฏเตเดฏเดพเตป เดคเตเดเดเตเดเดฟเดฏเดชเตเดชเตเตพ,
เดเดฑเดตเดฟเดเด - เดกเดพเดฑเตเดฑ เดเดฑเดตเดฟเดเด,
เดฒเตเดฏเตผ - เดเดคเต เดธเดเดญเดฐเดฃ โโเดจเดฟเดฒเดฏเดพเดฃเต เดฒเตเดกเต เดเตเดฏเตเดคเดฟเดฐเดฟเดเตเดเตเดจเตเดจเดคเต,
ETL เดเตเดฌเต เดจเตเดฏเดฟเด เดเดจเตเดจเดคเต เดจเดฟเดฐเดตเดงเดฟ เดเตเดฑเดฟเดฏ เดเดเตเดเดเตเดเตพ เดเตพเดเตเดเตเดณเตเดณเตเดจเตเดจ เดเดฐเต เดฒเตเดกเดฟเดเดเต เดจเดเดชเดเดฟเดเตเดฐเดฎเดฎเดพเดฃเต,
เดธเตเดฑเตเดฑเตเดชเตเดชเต เดจเดฎเตเดชเตผ - เดจเดเดชเตเดชเดฟเดฒเดพเดเตเดเตเดจเตเดจ เดเดเตเดเดคเตเดคเดฟเดจเตเดฑเต เดเดฃเตเดฃเด,
เดฌเดพเดงเดฟเดเตเด เดตเดฐเดฟเดเตพ - เดเดคเตเดฐ เดกเดพเดฑเตเดฑ เดเดคเดฟเดจเดเด เดชเตเดฐเตเดธเดธเตเดธเต เดเตเดฏเตเดคเต,
เดฆเตเตผเดเตเดฏเด เดธเตเดเตเดเดจเตเดฑเต - เดเดเตเดธเดฟเดเตเดฏเตเดเตเดเต เดเตเดฏเตเดฏเดพเตป เดเดคเตเดฐ เดธเดฎเดฏเดฎเตเดเตเดเตเดเตเด,
เดธเตเดฑเตเดฑเดพเดฑเตเดฑเดธเต - เดเดฒเตเดฒเดพเด เดจเดฒเตเดฒเดคเดพเดฃเตเดเตเดเดฟเดฒเตเด เด
เดฒเตเดฒเตเดเตเดเดฟเดฒเตเด: เดถเดฐเดฟ, เดชเดฟเดถเดเต, เดเดเตเดเด, เดนเดพเดเดเตเดธเต
เดธเดจเตเดฆเตเดถเด โ เด
เดตเดธเดพเดจเดคเตเดคเต เดตเดฟเดเดฏเดเดฐเดฎเดพเดฏ เดธเดจเตเดฆเตเดถเด เด
เดฒเตเดฒเตเดเตเดเดฟเตฝ เดชเดฟเดถเดเต เดตเดฟเดตเดฐเดฃเด.
เดฐเตเดเดเดณเตเดเต เดจเดฟเดฒเดฏเต เด เดเดฟเดธเตเดฅเดพเดจเดฎเดพเดเตเดเดฟ, เดจเดฟเดเตเดเตพเดเตเดเต เดเดฐเต เดเดฎเตเดฏเดฟเตฝ เด เดฏเดฏเตเดเตเดเดพเตป เดเดดเดฟเดฏเตเด. เดฎเดฑเตเดฑเต เดชเดเตเดเดพเดณเดฟเดเตพเดเตเดเตเดณเตเดณ เดเดคเตเดคเต. เดชเดฟเดถเดเตเดเดณเตเดจเตเดจเตเดฎเดฟเดฒเตเดฒเตเดเตเดเดฟเตฝ, เดเดฐเต เดเดคเตเดคเต เดเดตเดถเตเดฏเดฎเดฟเดฒเตเดฒ.
เด เดฐเตเดคเดฟเดฏเดฟเตฝ, เดเดฐเต เดชเดฟเดถเดเต เดธเดเดญเดตเดฟเดเตเดเดพเตฝ, เดธเดเดญเดตเดคเตเดคเดฟเดจเตเดฑเต เดธเตเดฅเดพเดจเด เดตเตเดฏเดเตเดคเดฎเดพเดฏเดฟ เดธเตเดเดฟเดชเตเดชเดฟเดเตเดเดฟเดฐเดฟเดเตเดเตเดจเตเดจเต.
เดเดฟเดฒเดชเตเดชเตเตพ เดฎเตเดฃเดฟเดฑเตเดฑเดฑเดฟเดเดเต เดเตเตพ เดคเดจเตเดจเต เดชเตเดฐเดตเตผเดคเตเดคเดฟเดเตเดเตเดจเตเดจเดฟเดฒเตเดฒเตเดจเตเดจเต เดธเดเดญเดตเดฟเดเตเดเตเดจเตเดจเต. เด เดธเดพเดนเดเดฐเตเดฏเดคเตเดคเดฟเตฝ, เดฑเดฟเดชเตเดชเตเตผเดเตเดเต เดจเดฟเตผเดฎเตเดฎเดฟเดเตเดเดคเดฟเดจเตเดฑเต เด เดเดฟเดธเตเดฅเดพเดจเดคเตเดคเดฟเตฝ, เดกเดพเดฑเตเดฑเดพเดฌเตเดธเดฟเตฝ เดจเตเดฐเดฟเดเตเดเต เดเดพเดดเตเด (เดเดพเดดเตเด) เดตเดฟเดณเดฟเดเตเดเดพเตป เดธเดพเดงเดฟเดเตเดเตเด.
ETL เดจเดฟเดฐเตเดเตเดทเดฃ เดชเดเตเดเดฟเด
ETL เดชเตเดฐเดเตเดฐเดฟเดฏเดเดณเตเดเต เดจเดฟเดฐเตเดเตเดทเดฃเด เดจเดเดชเตเดชเดฟเดฒเดพเดเตเดเดพเตป, เดเดฐเต เดชเดเตเดเดฟเดเดฏเตเด เดเดฐเต เดเดพเดดเตเดเดฏเตเด เดฎเดคเดฟ.
เดเดคเต เดเตเดฏเตเดฏเตเดจเตเดจเดคเดฟเดจเต, เดจเดฟเดเตเดเตพเดเตเดเต เดเดคเดฟเดฒเตเดเตเดเต เดฎเดเดเตเดเดพเด
DDL เดชเดเตเดเดฟเดเดเตพ
CREATE TABLE UTL_JOB_STATUS (
/* Table for logging of job execution log. Important that the job has the steps ETL_START and ETL_END or ETL_ERROR */
UTL_JOB_STATUS_ID INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
SID INTEGER NOT NULL DEFAULT -1, /* Session Identificator. Unique for every Run of job */
LOG_DT INTEGER NOT NULL DEFAULT 0, /* Date time */
LOG_D INTEGER NOT NULL DEFAULT 0, /* Date */
JOB_NAME TEXT NOT NULL DEFAULT 'N/A', /* Job name like JOB_STG2DM_GEO */
STEP_NAME TEXT NOT NULL DEFAULT 'N/A', /* ETL_START, ... , ETL_END/ETL_ERROR */
STEP_DESCR TEXT, /* Description of task or error message */
UNIQUE (SID, JOB_NAME, STEP_NAME)
);
INSERT INTO UTL_JOB_STATUS (UTL_JOB_STATUS_ID) VALUES (-1);
DDL เดเดพเดฃเตเด/เดฑเดฟเดชเตเดชเตเตผเดเตเดเต เดเตเดฏเตเดฏเตเด
CREATE VIEW IF NOT EXISTS UTL_JOB_STATUS_V
AS /* Content: Package Execution Log for last 3 Months. */
WITH SRC AS (
SELECT LOG_D,
LOG_DT,
UTL_JOB_STATUS_ID,
SID,
CASE WHEN INSTR(JOB_NAME, 'FTP') THEN 'TRANSFER' /* file transfer */
WHEN INSTR(JOB_NAME, 'STG') THEN 'STAGE' /* stage */
WHEN INSTR(JOB_NAME, 'CLS') THEN 'CLEANSING' /* cleansing */
WHEN INSTR(JOB_NAME, 'DIM') THEN 'DIMENSION' /* dimension */
WHEN INSTR(JOB_NAME, 'FCT') THEN 'FACT' /* fact */
WHEN INSTR(JOB_NAME, 'ETL') THEN 'STAGE-MART' /* data mart */
WHEN INSTR(JOB_NAME, 'RPT') THEN 'REPORT' /* report */
ELSE 'N/A' END AS LAYER,
CASE WHEN INSTR(JOB_NAME, 'ACCESS') THEN 'ACCESS LOG' /* source */
WHEN INSTR(JOB_NAME, 'MASTER') THEN 'MASTER DATA' /* source */
WHEN INSTR(JOB_NAME, 'AD-HOC') THEN 'AD-HOC' /* source */
ELSE 'N/A' END AS SOURCE,
JOB_NAME,
STEP_NAME,
CASE WHEN STEP_NAME='ETL_START' THEN 1 ELSE 0 END AS START_FLAG,
CASE WHEN STEP_NAME='ETL_END' THEN 1 ELSE 0 END AS END_FLAG,
CASE WHEN STEP_NAME='ETL_ERROR' THEN 1 ELSE 0 END AS ERROR_FLAG,
STEP_NAME || ' : ' || STEP_DESCR AS STEP_LOG,
SUBSTR( SUBSTR(STEP_DESCR, INSTR(STEP_DESCR, '***')+4), 1, INSTR(SUBSTR(STEP_DESCR, INSTR(STEP_DESCR, '***')+4), '***')-2 ) AS AFFECTED_ROWS
FROM UTL_JOB_STATUS
WHERE datetime(LOG_D, 'unixepoch') >= date('now', 'start of month', '-3 month')
)
SELECT JB.SID,
JB.MIN_LOG_DT AS START_DT,
strftime('%d.%m.%Y %H:%M', datetime(JB.MIN_LOG_DT, 'unixepoch')) AS LOG_DT,
JB.SOURCE,
JB.LAYER,
JB.JOB_NAME,
CASE
WHEN JB.ERROR_FLAG = 1 THEN 'ERROR'
WHEN JB.ERROR_FLAG = 0 AND JB.END_FLAG = 0 AND strftime('%s','now') - JB.MIN_LOG_DT > 0.5*60*60 THEN 'HANGS' /* half an hour */
WHEN JB.ERROR_FLAG = 0 AND JB.END_FLAG = 0 THEN 'RUNNING'
ELSE 'OK'
END AS STATUS,
ERR.STEP_LOG AS STEP_LOG,
JB.CNT AS STEP_CNT,
JB.AFFECTED_ROWS AS AFFECTED_ROWS,
strftime('%d.%m.%Y %H:%M', datetime(JB.MIN_LOG_DT, 'unixepoch')) AS JOB_START_DT,
strftime('%d.%m.%Y %H:%M', datetime(JB.MAX_LOG_DT, 'unixepoch')) AS JOB_END_DT,
JB.MAX_LOG_DT - JB.MIN_LOG_DT AS JOB_DURATION_SEC
FROM
( SELECT SID, SOURCE, LAYER, JOB_NAME,
MAX(UTL_JOB_STATUS_ID) AS UTL_JOB_STATUS_ID,
MAX(START_FLAG) AS START_FLAG,
MAX(END_FLAG) AS END_FLAG,
MAX(ERROR_FLAG) AS ERROR_FLAG,
MIN(LOG_DT) AS MIN_LOG_DT,
MAX(LOG_DT) AS MAX_LOG_DT,
SUM(1) AS CNT,
SUM(IFNULL(AFFECTED_ROWS, 0)) AS AFFECTED_ROWS
FROM SRC
GROUP BY SID, SOURCE, LAYER, JOB_NAME
) JB,
( SELECT UTL_JOB_STATUS_ID, SID, JOB_NAME, STEP_LOG
FROM SRC
WHERE 1 = 1
) ERR
WHERE 1 = 1
AND JB.SID = ERR.SID
AND JB.JOB_NAME = ERR.JOB_NAME
AND JB.UTL_JOB_STATUS_ID = ERR.UTL_JOB_STATUS_ID
ORDER BY JB.MIN_LOG_DT DESC, JB.SID DESC, JB.SOURCE;
SQL เดเดฐเต เดชเตเดคเดฟเดฏ เดธเตเดทเตป เดจเดฎเตเดชเตผ เดจเตเดเดพเดจเตเดณเตเดณ เดเดดเดฟเดตเต เดชเดฐเดฟเดถเตเดงเดฟเดเตเดเตเดจเตเดจเต
SELECT SUM (
CASE WHEN start_job.JOB_NAME IS NOT NULL AND end_job.JOB_NAME IS NULL /* existed job finished */
AND NOT ( 'y' = 'n' ) /* force restart PARAMETER */
THEN 1 ELSE 0
END ) AS IS_RUNNING
FROM
( SELECT 1 AS dummy FROM UTL_JOB_STATUS WHERE sid = -1) d_job
LEFT OUTER JOIN
( SELECT JOB_NAME, SID, 1 AS dummy
FROM UTL_JOB_STATUS
WHERE JOB_NAME = 'RPT_ACCESS_LOG' /* job name PARAMETER */
AND STEP_NAME = 'ETL_START'
GROUP BY JOB_NAME, SID
) start_job /* starts */
ON d_job.dummy = start_job.dummy
LEFT OUTER JOIN
( SELECT JOB_NAME, SID
FROM UTL_JOB_STATUS
WHERE JOB_NAME = 'RPT_ACCESS_LOG' /* job name PARAMETER */
AND STEP_NAME in ('ETL_END', 'ETL_ERROR') /* stop status */
GROUP BY JOB_NAME, SID
) end_job /* ends */
ON start_job.JOB_NAME = end_job.JOB_NAME
AND start_job.SID = end_job.SID
เดชเดเตเดเดฟเด เดธเดตเดฟเดถเตเดทเดคเดเตพ:
- เดกเดพเดฑเตเดฑ เดชเตเดฐเตเดธเดธเตเดธเดฟเดเดเต เดจเดเดชเดเดฟเดเตเดฐเดฎเดคเตเดคเดฟเดจเตเดฑเต เดคเตเดเดเตเดเดตเตเด เด เดตเดธเดพเดจเดตเตเด ETL_START, ETL_END เดเดจเตเดจเต เดเดเตเดเดเตเดเตพเดเตเดเตเดชเตเดชเด เดเดฃเตเดเดพเดฏเดฟเดฐเดฟเดเตเดเดฃเด
- เดเดฐเต เดชเดฟเดถเดเต เดเดฃเตเดเดพเดฏเดพเตฝ, เด เดคเดฟเดจเตเดฑเต เดตเดฟเดตเดฐเดฃเดคเตเดคเตเดเตเดชเตเดชเด เดเดฐเต ETL_ERROR เดเดเตเดเด เดธเตเดทเตเดเดฟเดเตเดเตเดฃเตเดเดคเดพเดฃเต
- เดชเตเดฐเตเดธเดธเตเดธเต เดเตเดฏเตเดค เดกเดพเดฑเตเดฑเดฏเตเดเต เด เดณเดตเต เดนเตเดฒเตเดฑเตเดฑเต เดเตเดฏเตเดฏเดฃเด, เดเดฆเดพเดนเดฐเดฃเดคเตเดคเดฟเดจเต, เดจเดเตเดทเดคเตเดฐเดเดฟเดนเตเดจเดเตเดเตพ เดเดชเดฏเตเดเดฟเดเตเดเต
- เดเดฐเต เดธเดฎเดฏเด force_restart=y เดชเดพเดฐเดพเดฎเตเดฑเตเดฑเตผ เดเดชเดฏเตเดเดฟเดเตเดเต เด เดคเต เดจเดเดชเดเดฟเดเตเดฐเดฎเด เดเดฐเดเดญเดฟเดเตเดเดพเตป เดเดดเดฟเดฏเตเด; เดเดคเต เดเตเดเดพเดคเต, เดชเตเตผเดคเตเดคเดฟเดฏเดพเดฏ เดจเดเดชเดเดฟเดเตเดฐเดฎเดคเตเดคเดฟเดจเต เดฎเดพเดคเตเดฐเดฎเต เดธเตเดทเตป เดจเดฎเตเดชเตผ เดจเตฝเดเต.
- เดธเดพเดงเดพเดฐเดฃ เดฎเตเดกเดฟเตฝ เดเดฐเต เดกเดพเดฑเตเดฑ เดชเตเดฐเตเดธเดธเตเดธเดฟเดเดเต เดจเดเดชเดเดฟเดเตเดฐเดฎเด เดธเดฎเดพเดจเตเดคเดฐเดฎเดพเดฏเดฟ เดชเตเดฐเดตเตผเดคเตเดคเดฟเดชเตเดชเดฟเดเตเดเตเดจเตเดจเดคเต เด เดธเดพเดงเตเดฏเดฎเดพเดฃเต
เดชเดเตเดเดฟเดเดฏเดฟเตฝ เดชเตเดฐเดตเตผเดคเตเดคเดฟเดเตเดเตเดจเตเดจเดคเดฟเดจเต เดเดตเดถเตเดฏเดฎเดพเดฏ เดชเตเดฐเดตเตผเดคเตเดคเดจเดเตเดเตพ เดเดจเดฟเดชเตเดชเดฑเดฏเตเดจเตเดจเดตเดฏเดพเดฃเต:
- เดธเดฎเดพเดฐเดเดญเดฟเดเตเดเตเดจเตเดจ ETL เดจเดเดชเดเดฟเดเตเดฐเดฎเดคเตเดคเดฟเดจเตเดฑเต เดธเตเดทเตป เดจเดฎเตเดชเตผ เดจเตเดเตเดจเตเดจเต
- เดเดฐเต เดชเดเตเดเดฟเดเดฏเดฟเตฝ เดเดฐเต เดฒเตเดเต เดเตปเดเตเดฐเดฟ เดเตเตผเดเตเดเตเดจเตเดจเต
- เดเดฐเต ETL เดจเดเดชเดเดฟเดเตเดฐเดฎเดคเตเดคเดฟเดจเตเดฑเต เด เดตเดธเดพเดจ เดตเดฟเดเดฏเดเดฐเดฎเดพเดฏ เดฑเตเดเตเดเตเตผเดกเต เดจเตเดเตเดจเตเดจเต
Oracle เด
เดฒเตเดฒเตเดเตเดเดฟเตฝ Postgres เดชเตเดฒเตเดณเตเดณ เดกเดพเดฑเตเดฑเดพเดฌเตเดธเตเดเดณเดฟเตฝ, เด เดชเตเดฐเดตเตผเดคเตเดคเดจเดเตเดเตพ เดฌเดฟเตฝเดฑเตเดฑเต-เดเตป เดซเดเดเตเดทเดจเตเดเตพ เดเดชเดฏเตเดเดฟเดเตเดเต เดจเดเดชเตเดชเดฟเดฒเดพเดเตเดเดพเตป เดเดดเดฟเดฏเตเด. sqlite-เดจเต เดเดฐเต เดฌเดพเดนเตเดฏ เดธเดเดตเดฟเดงเดพเดจเด เดเดตเดถเตเดฏเดฎเดพเดฃเต, เด เดธเดพเดนเดเดฐเตเดฏเดคเตเดคเดฟเตฝ เด
เดคเต
เดคเตเดฐเตเดฎเดพเดจเด
เด เดคเดฟเดจเดพเตฝ, เดกเดพเดฑเตเดฑ เดชเตเดฐเตเดธเดธเตเดธเดฟเดเดเต เดเตเดณเตเดเดณเดฟเดฒเต เดชเดฟเดถเดเต เดฑเดฟเดชเตเดชเตเตผเดเตเดเดฟเดเดเต เดเดฐเต เดฎเตเดเดพ-เดชเตเดฐเดงเดพเดจ เดชเดเตเดเต เดตเดนเดฟเดเตเดเตเดจเตเดจเต. เดเดจเตเดจเดพเตฝ เดชเตเดฐเดถเตเดจเดคเตเดคเดฟเดจเตเดฑเต เดเดพเดฐเดฃเด เดตเตเดเดคเตเดคเดฟเตฝ เดเดฃเตเดเตเดคเตเดคเตเดจเตเดจเดคเดฟเดจเต เด เดตเดฏเต เดเดชเตเดฑเตเดฑเดฟเดฎเตฝ เดเดจเตเดจเต เดตเดฟเดณเดฟเดเตเดเดพเดจเดพเดตเดฟเดฒเตเดฒ. เดจเดเดชเดเดฟเดเตเดฐเดฎเดเตเดเดณเตเดเต เดเดฃเตเดฃเด เดจเตเดฑเต เด เดเตเดเตเดเตเดฎเตเดชเตเตพ, เดชเตเดฐเดเตเดฐเดฟเดฏ เดจเดฟเดฐเตเดเตเดทเดฃเด เดเดฐเต เดธเดเตเดเตเตผเดฃเตเดฃ เดชเดฆเตเดงเดคเดฟเดฏเดพเดฏเดฟ เดฎเดพเดฑเตเดจเตเดจเต.
เดเดฐเต เดชเตเดฐเตเดเตเดเตเดเตเดชเตเดชเดฟเดจเตเดฑเต เดฐเตเดชเดคเตเดคเดฟเตฝ เดชเตเดฐเดถเตเดจเดคเตเดคเดฟเดจเต เดธเดพเดงเตเดฏเดฎเดพเดฏ เดชเดฐเดฟเดนเดพเดฐเดคเตเดคเดฟเดจเตเดฑเต เดเดฐเต เดเดฆเดพเดนเดฐเดฃเด เดฒเตเดเดจเด เดจเตฝเดเตเดจเตเดจเต. เดเตเดฑเดฟเดฏ เดถเตเดเดฐเดฃเดคเตเดคเดฟเดจเตเดฑเต เดฎเตเดดเตเดตเตป เดชเตเดฐเตเดเตเดเตเดเตเดชเตเดชเตเด gitlab-เตฝ เดฒเดญเตเดฏเดฎเดพเดฃเต
เด
เดตเดฒเดเดฌเด: www.habr.com