使用到的知识点:

1、使用with临时存储sql语句,格式【with as xxx(), as xxx2() 】以减少代码;

2、使用round()取小数点后几位;

3、使用to_char()将时间格式的数据转换为text型;

4、使用split_part(xx,xx2,xx3)函数对文本型数据进行切分;

5、使用group by之后利用count()进行统计;

6、join 以及 left join之间的区别;

7、使用join连接多个表,基本格式:【a join b on a.id = b.id join c on a.id = c.id】;

8、嵌套查询(select * from (select * from ));

9、case xx when a then b else c end xx2:判断xx,如果满足a,赋值为b,否则赋值为c,最后取别名xx2;

10、使用current_date获取年月日:2021-01-28,使用now()获取当前时间戳,使用select to_char(now(),'YYYY')获取年;

11、使用【||】进行字符串的拼接;

12、使用to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' )将CURRENT_DATE 拼接时间后转时间戳;

13、使用【时间戳 + '-1 day'】进行时间戳的天数减一;

14、使用:【字段::类型】可以将字段转换为指定类型,或者使用【cast(字段 as 类型)】;

15、使用【insert into 表名(字段名1,字段名2) select  * from 表名2 】将查询出来的值批量添加到另一个表中;

with tmp as (
select * from (
select
d1.user_id,
d1.company_name,
d1.website_name,
d1.source_top,
round( 100 * d1.source_top / d2.news_num, 2 ) AS ratio,
row_number( ) OVER ( PARTITION BY d1.user_id, d1.company_name ) AS row_num
from
(SELECT
t1.user_id,
split_part ( t2.monitor_words_company, '#;#', 1 ) AS company_name,
website_name AS website_name,
count( website_name ) AS source_top
FROM
service.eoias_sentiment_analysis_result t1
JOIN service.eoias_crawler_key_param t2 ON t1.case_id = cast( t2.id AS text )
WHERE
t1.release_time >= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) + '-1 day'
AND t1.release_time <= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' )
GROUP BY
t1.user_id,
company_name,
website_name) d1
join
(SELECT
user_id,
company_name,
count( company_name ) AS news_num
FROM
(
SELECT
t1.user_id AS user_id,
t1.case_id AS case_id,
split_part ( t2.monitor_words_company, '#;#', 1 ) AS company_name,
website_name AS website_name,
CURRENT_DATE AS daily_date
FROM
service.eoias_sentiment_analysis_result t1
JOIN service.eoias_crawler_key_param t2 ON t1.case_id = cast( t2.id AS text )
WHERE
t1.release_time >= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) + '-1 day'
AND t1.release_time <= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) and t1.user_id = t2.user_id and t1.case_id = cast( t2.id AS text )
) c1
GROUP BY
c1.user_id,
company_name) d2
on d1.user_id = d2.user_id and d1.company_name = d2.company_name) e1 where row_num <=2
), tmp2 as (
SELECT
user_id,
company_name,
count( company_name ) AS news_num
FROM
(
SELECT
t1.user_id AS user_id,
t1.case_id AS case_id,
split_part ( t2.monitor_words_company, '#;#', 1 ) AS company_name,
website_name AS website_name,
CURRENT_DATE AS daily_date
FROM
service.eoias_sentiment_analysis_result t1
JOIN service.eoias_crawler_key_param t2 ON t1.case_id = cast( t2.id AS text )
WHERE
t1.release_time >= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) + '-1 day'
AND t1.release_time <= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) and t1.user_id = t2.user_id and t1.case_id = cast( t2.id AS text )
) c1
GROUP BY
c1.user_id,
company_name
), tmp3 as (
select user_id,company_name,sentiment_top1,sentiment_top1_num,sentiment_top1_ratio from (
SELECT
c1.user_id,
c1.company_name,
c1.text_sentiment as sentiment_top1,
c1.sentiment_top as sentiment_top1_num,
round(100 * c1.sentiment_top / c2.news_num, 2) as sentiment_top1_ratio,
row_number() over (partition by c1.user_id, c1.company_name) as rown
FROM
(
SELECT
t1.user_id,
split_part ( t2.monitor_words_company, '#;#', 1 ) AS company_name,
t1.text_sentiment,
count( 1 ) AS sentiment_top
FROM
service.eoias_sentiment_analysis_result t1
JOIN service.eoias_crawler_key_param t2 ON t1.case_id = cast( t2.id AS text )
WHERE
t1.release_time >= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) + '-1 day'
AND t1.release_time <= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' )
GROUP BY
t1.user_id,
company_name,
text_sentiment
) c1
JOIN (
SELECT
user_id,
company_name,
count( company_name ) AS news_num
FROM
(
SELECT
t1.user_id AS user_id,
t1.case_id AS case_id,
split_part ( t2.monitor_words_company, '#;#', 1 ) AS company_name,
website_name AS website_name,
CURRENT_DATE AS daily_date
FROM
service.eoias_sentiment_analysis_result t1
JOIN service.eoias_crawler_key_param t2 ON t1.case_id = cast( t2.id AS text )
WHERE
t1.release_time >= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) + '-1 day'
AND t1.release_time <= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' )
AND t1.user_id = t2.user_id
AND t1.case_id = cast( t2.id AS text )
) c1
GROUP BY
c1.user_id,
company_name
) c2 ON c1.user_id = c2.user_id
AND c1.company_name = c2.company_name) d1 where rown = '1'
) insert into daily.eoias_daily_abstract(user_id,case_id,daily_date,company_name,news_num,source_top1,source_top1_num,source_top1_ratio,source_top2,source_top2_num,source_top2_ratio,sentiment_top1,sentiment_top1_num,sentiment_top1_ratio)
select
c.user_id,
c.case_id,
to_char(now()::timestamp,'YYYYmmdd') as daily_date,
c.company_name,
tmp2.news_num,
tmp1.source_top1,
tmp1.source_top1_num,
tmp1.source_top1_ratio,
tmp1.source_top2,
tmp1.source_top2_num,
tmp1.source_top2_ratio,
tmp3.sentiment_top1,
tmp3.sentiment_top1_num,
tmp3.sentiment_top1_ratio
from (
SELECT
a.user_id,
a.case_id,
split_part ( b.monitor_words_company, '#;#', 1 ) AS company_name
FROM
service.eoias_sentiment_analysis_result a
JOIN service.eoias_crawler_key_param b ON a.case_id = cast( b.id AS text )
WHERE
a.release_time >= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss' ) + '-1 day'
AND a.release_time <= to_timestamp ( CURRENT_DATE || ' ' || '07:00:00', 'yyyy-MM-dd hh24:mi:ss')) c
join (select
a.user_id,
a.company_name,
a.website_name as source_top1,
a.source_top as source_top1_num,
a.ratio as source_top1_ratio,
case when b.website_name is null then '' else b.website_name end source_top2,
case when b.source_top is null then 0 else b.source_top end source_top2_num,
case when b.ratio is null then 0 else b.ratio end source_top2_ratio
from
(select user_id, company_name, website_name, ratio, source_top from tmp where row_num = 1) a
left join
(select user_id, company_name, website_name, ratio, source_top from tmp where row_num = 2) b
on a.company_name = b.company_name and a.user_id = b.user_id) tmp1 on c.user_id = tmp1.user_id and c.company_name = tmp1.company_name
join tmp2 on c.user_id = tmp2.user_id and c.company_name = tmp2.company_name
join tmp3 on c.user_id = tmp3.user_id and c.company_name = tmp3.company_name;

postgres多知识点综合案例的更多相关文章

  1. swiper快速切换插件(两个综合案例源码)

    swiper快速切换插件 swiper.js自己去官网下载哈.先来一个tab切换案例: demo.html <!doctype html> <html> <head> ...

  2. 075 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 07 综合案例-数组移位-主方法功能4的实现

    075 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 07 综合案例-数组移位-主方法功能4的实现 本文知识点:综合案例-数组移位-主方法功能4的实现 说明:因为 ...

  3. 074 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 06 综合案例-数组移位-主方法功能3的实现

    074 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 06 综合案例-数组移位-主方法功能3的实现 本文知识点:综合案例-数组移位-主方法功能3的实现 说明:因为 ...

  4. 073 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 05 综合案例-数组移位-主方法功能1和2的实现

    073 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 05 综合案例-数组移位-主方法功能1和2的实现 本文知识点:综合案例-数组移位-主方法功能1和2的实现 说 ...

  5. 072 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 04 综合案例-数组移位-在指定位置处插入数据方法

    072 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 04 综合案例-数组移位-在指定位置处插入数据方法 本文知识点:综合案例-数组移位-在指定位置处插入数据方法 ...

  6. 071 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 03 综合案例-数组移位-显示数组当中所有元素的的方法

    071 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 03 综合案例-数组移位-显示数组当中所有元素的的方法 本文知识点:综合案例-数组移位-显示数组当中所有元素 ...

  7. 070 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 02 综合案例-数组移位-从键盘接收数据

    070 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 02 综合案例-数组移位-从键盘接收数据 本文知识点:综合案例-数组移位-从键盘接收数据 说明:因为时间紧张 ...

  8. 069 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 01 综合案例-数组移位-案例需求

    069 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 01 综合案例-数组移位-案例需求 本文知识点:综合案例-数组移位-案例需求 说明:因为时间紧张,本人写博客 ...

  9. 032 01 Android 零基础入门 01 Java基础语法 03 Java运算符 12 运算符和if-else条件语句的综合案例——闰年问题

    032 01 Android 零基础入门 01 Java基础语法 03 Java运算符 12 运算符和if-else条件语句的综合案例--闰年问题 本文知识点:运算符和if-else条件语句的综合案例 ...

随机推荐

  1. 各公有云1核1G的云主机跑分对比

    本文主要测评华为云.腾讯云.阿里云 1H1G服务器的性能,为保证结果有效性,使用环境如下: 1.1H1G Ubuntu 16.04_x64 2.Unixbench Version 5.1.3,详细信息 ...

  2. 开发规范(二)如何写单元测试 By 阿里

  3. 卷积网络可解释性复现 | Grad-CAM | ICCV | 2017

    觉得本文不错的可以点个赞.有问题联系作者微信cyx645016617,之后主要转战公众号,不在博客园和CSDN更新. 论文名称:"Grad-CAM: Visual Explanations ...

  4. mybatis实现MySQL数据库的增删改查之二

    这里直接附上代码: 1 package com.qijian.pojo; 2 3 import org.apache.ibatis.type.Alias; 4 5 6 public class Use ...

  5. 记 CentOS 服务器上安装 neo4j 图数据库及本地访问

    下载 去官网下载压缩包放到服务器上.地址为neo4j 下载中心,我这里选择的是 Neo4j 3.5.25 (tar).具体如何做呢?我这里使用的是土方法,即先压缩包下载到本地电脑(win 10系统), ...

  6. Map集合,Map常用子类

    Map 集合 1,Collection中的集合,元素是孤立的,向季和忠储存的元素采用一个元素方式储存 2,Map中的集合,元素是成对存在的,每个元素中的集合称为双列集合 3,Collection中的集 ...

  7. 粉丝投稿!从2月份的面试被拒到如今的阿里P7,说一说自己学java以来的经验!

    个人近期面试情况 今年二月以来,我的面试除了一个用友的,基本其他都被毙了,可以说是非常残酷的.其中有很多自己觉得还面的不错的岗位,比如百度.跟谁学.好未来等公司.说实话,打击比较大. 情况基本上是从三 ...

  8. 漫谈JSON Web Token(JWT)

    一.背景 传统的单体应用基于cookie-session的身份验证流程一般是这样的: 用户向服务器发送账户和密码. 服务器验证账号密码成功后,相关数据(用户角色.登录时间等)都保存到当前会话中. 服务 ...

  9. 详细介绍如何自研一款"博客搬家"功能

    前言 现在的技术博客(社区)越来越多,比如:imooc.spring4All.csdn.cnblogs或者iteye等,有很多朋友可能在这些网站上都发表过博文,当有一天我们想自己搞一个博客网站时就会发 ...

  10. redis基础-Remote Dictionary Server

    Redis支持多个数据库,并且每个数据库的数据是隔离的不能共享,并且基于单机才有,如果是集群就没有数据库的概念. Redis默认支持16个数据库(可以通过配置文件支持更多,无上限),可以通过配置dat ...