# SELECT NVL(t2.partition_date,t3.partition_date) as partition_date
# ,NVL(t2.cl_id,t3.cl_id) as cl_id
# ,NVL(t2.query,t3.query) as query
# ,NVL(t2.pv,0) as hexin
# ,NVL(t3.pv,0) as neirong
# FROM
# (--核心卡片点击
# SELECT partition_date
# ,params['query'] as query
# ,cl_id
# ,count(1) as pv
# FROM online.bl_hdfs_maidian_updates
# WHERE partition_date >= {yesterday_str}
# AND partition_date < {today_str}
# AND ((action in ('search_result_click_recommend_item','search_result_welfare_click_item','search_result_hospital_click_item','search_result_doctor_click_item','on_click_doctor_card', 'on_click_hospital_card')
# AND page_name in ('search_result_more','search_result_welfare','search_result_hospital','search_result_doctor'))
# or (action = 'goto_welfare_detail' AND params [ 'from' ] = 'search_result_welfare_recommend')
# or (action = 'on_click_card' AND params['card_content_type'] in ('service','hospital','doctor') AND page_name in ('search_result_more','search_result_welfare','search_result_hospital','search_result_doctor'))
# or (action = 'on_click_button' AND params['button_name'] = 'check_plan' AND page_name = 'search_result_more'))
# GROUP BY partition_date
# ,params['query']
# ,cl_id
# )t2
# FULL JOIN
# (--内容卡片点击
# SELECT partition_date
# ,params['query'] as query
# ,cl_id
# ,count(1) as pv
# FROM online.bl_hdfs_maidian_updates
# WHERE partition_date >= {yesterday_str}
# AND partition_date < {today_str}
# AND ((action in ('on_click_topic_card','on_click_diary_card','search_result_click_infomation_item')
# AND page_name in ('search_result_more','search_result_diary','search_result_post'))
# or (action = 'on_click_card' AND params['card_content_type'] in ('answer','diary') AND page_name in ('search_result_more','search_result_diary','search_result_question_answer')))
AND ((action in ('search_result_click_recommend_item','search_result_welfare_click_item','search_result_hospital_click_item','search_result_doctor_click_item','on_click_doctor_card', 'on_click_hospital_card')
FROM online.bl_hdfs_maidian_updates
AND page_name in ('search_result_more','search_result_welfare','search_result_hospital','search_result_doctor'))
WHERE partition_date >= {yesterday_str}
or (action = 'goto_welfare_detail' AND params [ 'from' ] = 'search_result_welfare_recommend')
AND partition_date < {today_str}
or (action = 'on_click_card' AND params['card_content_type'] in ('service','hospital','doctor') AND page_name in ('search_result_more','search_result_welfare','search_result_hospital','search_result_doctor'))
AND action in ('do_search','search_result_click_search')
or (action = 'on_click_button' AND params['button_name'] = 'check_plan' AND page_name = 'search_result_more'))
GROUP BY partition_date
UNION ALL
,params['query']
SELECT partition_date,params['query'] as query,cl_id
,cl_id
FROM online.bl_hdfs_maidian_updates
)t2
WHERE partition_date >= {yesterday_str}
FULL JOIN
AND partition_date < {today_str}
(--内容卡片点击
AND action = 'on_click_card'
SELECT partition_date
AND params['page_name']='search_home'
,params['query'] as query
,cl_id
UNION ALL
,count(1) as pv
SELECT partition_date
FROM online.bl_hdfs_maidian_updates
,params['card_name'] as query
WHERE partition_date >= {yesterday_str}
,cl_id
AND partition_date < {today_str}
FROM online.bl_hdfs_maidian_updates
AND ((action in ('on_click_topic_card','on_click_diary_card','search_result_click_infomation_item')
WHERE partition_date >= {yesterday_str}
AND page_name in ('search_result_more','search_result_diary','search_result_post'))
AND partition_date < {today_str}
or (action = 'on_click_card' AND params['card_content_type'] in ('answer','diary') AND page_name in ('search_result_more','search_result_diary','search_result_question_answer')))
AND (is_puppet = 'true' or is_classifyuser = 'true')
(
SELECT NVL(t2.partition_date,t3.partition_date) as partition_date
UNION ALL
,NVL(t2.cl_id,t3.cl_id) as cl_id
--公司内网覆盖用户
,NVL(t2.query,t3.query) as query
select distinct user_id
,NVL(t2.pv,0) as hexin
from dim.dim_device_user_staff
,NVL(t3.pv,0) as neirong
FROM
UNION ALL
(--核心卡片点击
--登陆过医生设备
SELECT partition_date
SELECT distinct t1.user_id
,params['query'] as query
FROM
,cl_id
(
,count(1) as pv
SELECT user_id, v.device_id as device_id
FROM online.bl_hdfs_maidian_updates
FROM online.ml_user_history_detail
WHERE partition_date >= {yesterday_str}
LATERAL VIEW EXPLODE(device_history_list) v AS device_id
AND partition_date < {today_str}
WHERE partition_date = {yesterday_str}
AND ((action in ('search_result_click_recommend_item','search_result_welfare_click_item','search_result_hospital_click_item','search_result_doctor_click_item','on_click_doctor_card', 'on_click_hospital_card')
)t1
AND page_name in ('search_result_more','search_result_welfare','search_result_hospital','search_result_doctor'))
JOIN
or (action = 'goto_welfare_detail' AND params [ 'from' ] = 'search_result_welfare_recommend')
(
or (action = 'on_click_card' AND params['card_content_type'] in ('service','hospital','doctor') AND page_name in ('search_result_more','search_result_welfare','search_result_hospital','search_result_doctor'))
SELECT device_id
or (action = 'on_click_button' AND params['button_name'] = 'check_plan' AND page_name = 'search_result_more'))
FROM online.ml_device_history_detail
GROUP BY partition_date
WHERE partition_date = {yesterday_str}
,params['query']
AND is_login_doctor = '1'
,cl_id
)t2
)t2
ON t1.device_id = t2.device_id
FULL JOIN
)t2
(--内容卡片点击
on t1.user_id=t2.user_id
SELECT partition_date
group by t1.partition_date,device_id
,params['query'] as query
)dev1
,cl_id
on t1.partition_date=dev1.partition_date and t1.cl_id=dev1.device_id
,count(1) as pv
WHERE (spam_pv.device_id IS NULL or spam_pv.device_id ='')
FROM online.bl_hdfs_maidian_updates
and (dev1.device_id is null or dev1.device_id ='')
WHERE partition_date >= {yesterday_str}
GROUP BY t1.partition_date,active_type,device_os_type,channel
AND partition_date < {today_str}
)t4
AND ((action in ('on_click_topic_card','on_click_diary_card','search_result_click_infomation_item')
on t3.partition_date=t4.partition_date and t3.active_type=t4.active_type and t3.device_os_type = t4.device_os_type AND t3.channel = t4.channel
AND page_name in ('search_result_more','search_result_diary','search_result_post'))
or (action = 'on_click_card' AND params['card_content_type'] in ('answer','diary') AND page_name in ('search_result_more','search_result_diary','search_result_question_answer')))