pgsql SQL复杂查询示例

本文展示了如何在pgsql中进行复杂的SQL查询,包括使用WITH子句和LEFT JOIN操作。同时,讨论了在遇到长度不定的字符串时,如何通过特定字符进行截取,并提到了当分割符数量不固定时的处理方法。
摘要由CSDN通过智能技术生成

https://www.cnblogs.com/scode2/p/9044201.html


WITH tmp AS(
SELECT sum(sessioncount) as visitCount, appid from t_stat_visit where stattype = '1' GROUP BY appid
)
SELECT
t1.*, t2.visitCount
FROM
t_e_oauth_application t1 LEFT JOIN tmp t2 on t1.appid = t2.appid
WHERE
EXISTS (
SELECT
ID
FROM
t_e_app_version
WHERE
t1. ID = t_e_app_version.appid
AND t_e_app_version.status = '6'
)
AND t1.createorid = #{creatorId}
ORDER BY lastmodifytime DESC

 

 

截取字符串一般用 substring 就够用了。对于有些长度不定的就没法用这个函数了,但还是有规律的,可以某个字符分割。

如:(这是一个url,截取最后一部分。现在要取 - 后面部分内容)
8a59e88177ad5e70-20170317120301AB9E.plist
12b8d5c26d83a17f-20170308173008D5DD.plist

  • 这时需要 split_part 函数,如:
-- url 一共3个 - ,字符串被分成4部分,取最后一部分,那最后一个参数就是4
select split_part(fs.cdn_url ,'-', 4) from file_store fs
  • 如果 分割符 数量不一样怎么办,这里就要计算分割符的数量了
-- 将 1个分隔符 替换为 2个分隔符,然后用长度相减得到分隔符数
-- 最后 +1 是为了取最后一部分内容
select split_part(fs.cdn_url ,'-', 
    length(replace(fs.cdn_url,'-','--')) - length(fs.cdn_url) + 1) 
from file_store fs 

链接:https://www.jianshu.com/p/6eb8ff8311f8
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值