dw_channel_daily.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. """
  2. @desc 号维度全量表 ck上跑完dw_daily_channel 并同步到mysql dw_channel_daily
  3. @auth ck
  4. """
  5. import time
  6. from model.DateUtils import DateUtils
  7. from model.DataBaseUtils import MysqlUtils,CkUtils
  8. du = DateUtils()
  9. db= MysqlUtils()
  10. ck = CkUtils()
  11. def dw_daily_channel():
  12. print("run> dw_daily_channel")
  13. sql="""insert into dw_daily_channel
  14. select
  15. dt,channel,pitcher,stage,platform,book,
  16. order_count,order_user,order_amount,first_order_count,first_order_user,first_order_amount,
  17. view_count,click_count,follow_user,cost,reg_order_count,reg_order_user,
  18. reg_order_amount,reg_order_amount30,web_view_count,platform_view_count,web_order_count,
  19. 0 total_cost,0 total_amount,
  20. reg_order_user_again,reg_order_user7,reg_order_user30,reg_order_amount7,type,
  21. 0 total_first_amount,
  22. require_roi,require_mult
  23. from
  24. (select dt,channel, pitcher,stage,platform,book,cost,view_count,click_count,follow_user,web_view_count,platform_view_count,web_order_count,
  25. case type when 'vx' then 'MP' when 'qq' then 'GDT' else type end type,require_roi,require_mult from dw_daily_channel_cost) a
  26. left outer join
  27. (select toDate(formatDateTime(reg_time,'%Y-%m-%d')) as dt2,channel as channel2,
  28. sum(amount) as reg_order_amount,
  29. count(distinct user_id) as reg_order_user,
  30. count(1) as reg_order_count,
  31. sum(if(subtractDays(date, 30)>reg_time,0,amount)) as reg_order_amount30,
  32. count(distinct if(subtractDays(date, 7)>reg_time,'',user_id))-1 reg_order_user7,
  33. sum(if(subtractDays(date, 7)>reg_time,0,amount)) as reg_order_amount7,
  34. count(distinct if(subtractDays(date, 30)>reg_time,'',user_id))-1 reg_order_user30
  35. from order where reg_time>'2019-03-18 00:00:00' group by toDate(formatDateTime(reg_time,'%Y-%m-%d')),channel) b
  36. on dt=dt2 and channel=channel2 left outer join
  37. (select date as dt3,channel as channel3,
  38. count(1) as first_order_count,
  39. count(distinct user_id) as first_order_user,
  40. sum(amount) as first_order_amount
  41. from order where toDate(reg_time)=date group by date,channel) c
  42. on dt=dt3 and channel=channel3
  43. left outer join
  44. (select date as dt4,channel as channel4,
  45. count(1) as order_count,
  46. count(distinct user_id) as order_user,
  47. sum(amount) as order_amount
  48. from order group by date,channel) d
  49. on dt=dt4 and channel=channel4
  50. left outer join (
  51. select sum(if(user_order_count>1,1,0)) reg_order_user_again,channel channel6,toDate(reg_date) dt6 from (
  52. select formatDateTime(reg_time,'%Y-%m-%d') reg_date,channel,count(1) user_order_count
  53. from order group by formatDateTime(reg_time,'%Y-%m-%d') ,user_id,channel
  54. ) x group by reg_date,channel
  55. ) f on dt=dt6 and channel=channel6
  56. having order_amount+cost+reg_order_amount>0
  57. """
  58. ck.execute("truncate table dw_daily_channel")
  59. ck.execute(sql)
  60. print("ok")
  61. data=ck.execute('select * from dw_daily_channel')
  62. insert_sql="insert into dw_channel_daily values (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"
  63. db.quchen_text.execute("truncate table dw_channel_daily")
  64. db.quchen_text.executeMany(insert_sql,data)
  65. def dw_channel_daily():
  66. sql="""
  67. select
  68. dt,channel,pitcher,stage,platform,book,case type when 'vx' then 'MP' when 'qq' then 'GDT' else type end type,
  69. order_count,order_user,order_amount,
  70. first_order_count,first_order_user,first_order_amount,
  71. view_count,click_count,follow_user,
  72. cost,reg_order_count,reg_order_user,reg_order_amount,
  73. web_view_count,platform_view_count,web_order_count,
  74. reg_order_user_again,
  75. reg_order_user_again3,
  76. reg_order_user_again4,
  77. reg_order_user_again5,
  78. reg_order_user_again6
  79. from
  80. (select dt,channel, pitcher,stage,platform,book,cost,view_count,click_count, ---基础属性和消耗数据
  81. follow_user,web_view_count,platform_view_count,web_order_count,type,
  82. require_roi,require_mult from dw_daily_channel_cost) a
  83. left outer join
  84. (select date as dt3,channel as channel3,count(1) as first_order_count, ---新用户首日充值
  85. count(distinct user_id) as first_order_user,sum(amount) as first_order_amount
  86. from order where toDate(reg_time)=date group by date,channel) c
  87. on dt=dt3 and channel=channel3
  88. left outer join
  89. (select date as dt4,channel as channel4,count(1) as order_count, ---账面充值
  90. count(distinct user_id) as order_user,sum(amount) as order_amount
  91. from order group by date,channel) d
  92. on dt=dt4 and channel=channel4
  93. left outer join (
  94. select sum(if(user_order_count>=2,1,0)) reg_order_user_again,channel channel6,toDate(reg_date) dt6, ---复冲人数
  95. sum(if(user_order_count>=3,1,0)) reg_order_user_again3,
  96. sum(if(user_order_count>=4,1,0)) reg_order_user_again4,
  97. sum(if(user_order_count>=5,1,0)) reg_order_user_again5,
  98. sum(if(user_order_count>=6,1,0)) reg_order_user_again6
  99. from (select formatDateTime(reg_time,'%Y-%m-%d') reg_date,channel,count(1) user_order_count
  100. from order group by formatDateTime(reg_time,'%Y-%m-%d') ,user_id,channel) x group by reg_date,channel
  101. ) f on dt=dt6 and channel=channel6
  102. left outer join
  103. (
  104. select toDate(formatDateTime(reg_time,'%Y-%m-%d')) as dt2, ---新用户累计充值数据
  105. channel as channel2,
  106. sum(amount) as reg_order_amount,
  107. count(distinct user_id) as reg_order_user,
  108. count(1) as reg_order_count
  109. from order where reg_time>'2019-03-18 00:00:00' group by toDate(formatDateTime(reg_time,'%Y-%m-%d')),channel) b
  110. on dt=dt2 and channel=channel2
  111. having order_amount+cost+reg_order_amount>0"""
  112. data=ck.execute(sql)
  113. isql="insert into dw_channel values (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"
  114. db.dm.execute("truncate table dw_channel")
  115. db.dm.executeMany(isql,data)
  116. def dw_channel_user_daily():
  117. sql="""
  118. select toDate(formatDateTime(reg_time,'%Y-%m-%d')) as dt,
  119. channel,
  120. count(distinct if(subtractDays(date, 1)>=toDate(reg_time),null,user_id)) dc1,
  121. count(distinct if(subtractDays(date, 2)>=toDate(reg_time),null,user_id)) dc2,
  122. count(distinct if(subtractDays(date, 3)>=toDate(reg_time),null,user_id)) dc3,
  123. count(distinct if(subtractDays(date, 4)>=toDate(reg_time),null,user_id)) dc4,
  124. count(distinct if(subtractDays(date, 5)>=toDate(reg_time),null,user_id)) dc5,
  125. count(distinct if(subtractDays(date, 6)>=toDate(reg_time),null,user_id)) dc6,
  126. count(distinct if(subtractDays(date, 7)>=toDate(reg_time),null,user_id)) dc7,
  127. count(distinct if(subtractDays(date, 8)>=toDate(reg_time),null,user_id)) dc8,
  128. count(distinct if(subtractDays(date, 9)>=toDate(reg_time),null,user_id)) dc9,
  129. count(distinct if(subtractDays(date, 10)>=toDate(reg_time),null,user_id)) dc10,
  130. count(distinct if(subtractDays(date, 11)>=toDate(reg_time),null,user_id)) dc11,
  131. count(distinct if(subtractDays(date, 12)>=toDate(reg_time),null,user_id)) dc12,
  132. count(distinct if(subtractDays(date, 13)>=toDate(reg_time),null,user_id)) dc13,
  133. count(distinct if(subtractDays(date, 14)>=toDate(reg_time),null,user_id)) dc14,
  134. count(distinct if(subtractDays(date, 15)>=toDate(reg_time),null,user_id)) dc15,
  135. count(distinct if(subtractDays(date, 16)>=toDate(reg_time),null,user_id)) dc16,
  136. count(distinct if(subtractDays(date, 17)>=toDate(reg_time),null,user_id)) dc17,
  137. count(distinct if(subtractDays(date, 18)>=toDate(reg_time),null,user_id)) dc18,
  138. count(distinct if(subtractDays(date, 19)>=toDate(reg_time),null,user_id)) dc19,
  139. count(distinct if(subtractDays(date, 20)>=toDate(reg_time),null,user_id)) dc20,
  140. count(distinct if(subtractDays(date, 21)>=toDate(reg_time),null,user_id)) dc21,
  141. count(distinct if(subtractDays(date, 22)>=toDate(reg_time),null,user_id)) dc22,
  142. count(distinct if(subtractDays(date, 23)>=toDate(reg_time),null,user_id)) dc23,
  143. count(distinct if(subtractDays(date, 24)>=toDate(reg_time),null,user_id)) dc24,
  144. count(distinct if(subtractDays(date, 25)>=toDate(reg_time),null,user_id)) dc25,
  145. count(distinct if(subtractDays(date, 26)>=toDate(reg_time),null,user_id)) dc26,
  146. count(distinct if(subtractDays(date, 27)>=toDate(reg_time),null,user_id)) dc27,
  147. count(distinct if(subtractDays(date, 28)>=toDate(reg_time),null,user_id)) dc28,
  148. count(distinct if(subtractDays(date, 29)>=toDate(reg_time),null,user_id)) dc29,
  149. count(distinct if(subtractDays(date, 30)>=toDate(reg_time),null,user_id)) dc30
  150. from order where reg_time>'2019-03-18 00:00:00' group by toDate(formatDateTime(reg_time,'%Y-%m-%d')),channel"""
  151. data =ck.execute(sql)
  152. isql="insert into dw_channel_user_daily values " \
  153. "(%s,%s,%s,%s,%s,%s,%s,%s,%s,%s," \
  154. "%s,%s,%s,%s,%s,%s,%s,%s,%s,%s," \
  155. "%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"
  156. db.dm.execute("truncate table dw_channel_user_daily")
  157. db.dm.executeMany(isql,data)
  158. def dw_channel_amount_daily():
  159. sql="""
  160. select toDate(formatDateTime(reg_time,'%Y-%m-%d')) as dt,
  161. channel as channel,
  162. sum(if(subtractDays(date, 1)>=toDate(reg_time),0,amount)) as da1,
  163. sum(if(subtractDays(date, 2)>=toDate(reg_time),0,amount)) as da2,
  164. sum(if(subtractDays(date, 3)>=toDate(reg_time),0,amount)) as da3,
  165. sum(if(subtractDays(date, 4)>=toDate(reg_time),0,amount)) as da4,
  166. sum(if(subtractDays(date, 5)>=toDate(reg_time),0,amount)) as da5,
  167. sum(if(subtractDays(date, 6)>=toDate(reg_time),0,amount)) as da6,
  168. sum(if(subtractDays(date, 7)>=toDate(reg_time),0,amount)) as da7,
  169. sum(if(subtractDays(date, 8)>=toDate(reg_time),0,amount)) as da8,
  170. sum(if(subtractDays(date, 9)>=toDate(reg_time),0,amount)) as da9,
  171. sum(if(subtractDays(date, 10)>=toDate(reg_time),0,amount)) as da10,
  172. sum(if(subtractDays(date, 11)>=toDate(reg_time),0,amount)) as da11,
  173. sum(if(subtractDays(date, 12)>=toDate(reg_time),0,amount)) as da12,
  174. sum(if(subtractDays(date, 13)>=toDate(reg_time),0,amount)) as da13,
  175. sum(if(subtractDays(date, 14)>=toDate(reg_time),0,amount)) as da14,
  176. sum(if(subtractDays(date, 15)>=toDate(reg_time),0,amount)) as da15,
  177. sum(if(subtractDays(date, 16)>=toDate(reg_time),0,amount)) as da16,
  178. sum(if(subtractDays(date, 17)>=toDate(reg_time),0,amount)) as da17,
  179. sum(if(subtractDays(date, 18)>=toDate(reg_time),0,amount)) as da18,
  180. sum(if(subtractDays(date, 19)>=toDate(reg_time),0,amount)) as da19,
  181. sum(if(subtractDays(date, 20)>=toDate(reg_time),0,amount)) as da20,
  182. sum(if(subtractDays(date, 21)>=toDate(reg_time),0,amount)) as da21,
  183. sum(if(subtractDays(date, 22)>=toDate(reg_time),0,amount)) as da22,
  184. sum(if(subtractDays(date, 23)>=toDate(reg_time),0,amount)) as da23,
  185. sum(if(subtractDays(date, 24)>=toDate(reg_time),0,amount)) as da24,
  186. sum(if(subtractDays(date, 25)>=toDate(reg_time),0,amount)) as da25,
  187. sum(if(subtractDays(date, 26)>=toDate(reg_time),0,amount)) as da26,
  188. sum(if(subtractDays(date, 27)>=toDate(reg_time),0,amount)) as da27,
  189. sum(if(subtractDays(date, 28)>=toDate(reg_time),0,amount)) as da28,
  190. sum(if(subtractDays(date, 29)>=toDate(reg_time),0,amount)) as da29,
  191. sum(if(subtractDays(date, 30)>=toDate(reg_time),0,amount)) as da30,
  192. sum(if(subtractDays(date, 31)>=toDate(reg_time),0,amount)) as da31,
  193. sum(if(subtractDays(date, 32)>=toDate(reg_time),0,amount)) as da32,
  194. sum(if(subtractDays(date, 33)>=toDate(reg_time),0,amount)) as da33,
  195. sum(if(subtractDays(date, 34)>=toDate(reg_time),0,amount)) as da34,
  196. sum(if(subtractDays(date, 35)>=toDate(reg_time),0,amount)) as da35,
  197. sum(if(subtractDays(date, 36)>=toDate(reg_time),0,amount)) as da36,
  198. sum(if(subtractDays(date, 37)>=toDate(reg_time),0,amount)) as da37,
  199. sum(if(subtractDays(date, 38)>=toDate(reg_time),0,amount)) as da38,
  200. sum(if(subtractDays(date, 39)>=toDate(reg_time),0,amount)) as da39,
  201. sum(if(subtractDays(date, 40)>=toDate(reg_time),0,amount)) as da40,
  202. sum(if(subtractDays(date, 41)>=toDate(reg_time),0,amount)) as da41,
  203. sum(if(subtractDays(date, 42)>=toDate(reg_time),0,amount)) as da42,
  204. sum(if(subtractDays(date, 43)>=toDate(reg_time),0,amount)) as da43,
  205. sum(if(subtractDays(date, 44)>=toDate(reg_time),0,amount)) as da44,
  206. sum(if(subtractDays(date, 45)>=toDate(reg_time),0,amount)) as da45,
  207. sum(if(subtractDays(date, 46)>=toDate(reg_time),0,amount)) as da46,
  208. sum(if(subtractDays(date, 47)>=toDate(reg_time),0,amount)) as da47,
  209. sum(if(subtractDays(date, 48)>=toDate(reg_time),0,amount)) as da48,
  210. sum(if(subtractDays(date, 49)>=toDate(reg_time),0,amount)) as da49,
  211. sum(if(subtractDays(date, 50)>=toDate(reg_time),0,amount)) as da50,
  212. sum(if(subtractDays(date, 51)>=toDate(reg_time),0,amount)) as da51,
  213. sum(if(subtractDays(date, 52)>=toDate(reg_time),0,amount)) as da52,
  214. sum(if(subtractDays(date, 53)>=toDate(reg_time),0,amount)) as da53,
  215. sum(if(subtractDays(date, 54)>=toDate(reg_time),0,amount)) as da54,
  216. sum(if(subtractDays(date, 55)>=toDate(reg_time),0,amount)) as da55,
  217. sum(if(subtractDays(date, 56)>=toDate(reg_time),0,amount)) as da56,
  218. sum(if(subtractDays(date, 57)>=toDate(reg_time),0,amount)) as da57,
  219. sum(if(subtractDays(date, 58)>=toDate(reg_time),0,amount)) as da58,
  220. sum(if(subtractDays(date, 59)>=toDate(reg_time),0,amount)) as da59,
  221. sum(if(subtractDays(date, 60)>=toDate(reg_time),0,amount)) as da60,
  222. sum(if(subtractDays(date, 90)>=toDate(reg_time),0,amount)) as dm3,
  223. sum(if(subtractDays(date, 120)>=toDate(reg_time),0,amount)) as dm4,
  224. sum(if(subtractDays(date, 150)>=toDate(reg_time),0,amount)) as dm5
  225. from order where reg_time>'2019-03-18 00:00:00' group by toDate(formatDateTime(reg_time,'%Y-%m-%d')),channel"""
  226. data=ck.execute(sql)
  227. isql="insert into dw_channel_amount_daily values (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s," \
  228. "%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)"
  229. db.dm.execute("truncate table dw_channel_amount_daily")
  230. db.dm.executeMany(isql,data)
  231. def dw_channel():
  232. print('run> dw_channel')
  233. dw_channel_daily()
  234. dw_channel_user_daily()
  235. dw_channel_amount_daily()
  236. if __name__ == '__main__':
  237. # dw_daily_channel()
  238. dw_channel()
  239. # dw_channel_amount_daily()
  240. # dw_channel_user_daily()