把这几张表的数据放在一起,怎么实现这条sql语句

发布于 2021-11-23 20:32:49 字数 1711 浏览 830 评论 3


把这几张表的数据放在一起,怎么实现这条sql语句  

怎么把发送人数表,和订阅人数表,通过营销id 关联查询起来


  --营销活动-用户关系表

  select t.*, t.rowid from marketing_userinfo t

  

  --发送人数

    select   count(1) from service_user d where  d.service_id=( select p.service_id    from service_type p 

    where p.service_id =(  select n.service_id  from service_marketing n  where n.marketing_id =2264) )

    

    --订阅人数

     select t.marketing_id ,t.userinfo_id from marketing_userinfo t group by t.marketing_id,t.userinfo_id


 -- 被订阅的 营销活动

select e.* from marketing e where e.marketing_id in ( select   t.marketing_id from marketing_userinfo t)


如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

草莓味的萝莉 2021-11-27 23:58:34

神马数据库?

如果是oracle的话可以发送人数建一个视图

订阅人数建一个视图

被订阅的 营销活动建一个视图

然后3个视图联合起来查询。

或者select from (select t.*, t.rowid from marketing_userinfo t) tabl1,(select t.marketing_id ,t.userinfo_id from marketing_userinfo t group by t.marketing_id,t.userinfo_id) table2,(select e.* from marketing e where e.marketing_id in ( select   t.marketing_id from marketing_userinfo t) table 3 where xxxxx

明月松间行 2021-11-27 01:11:39

这个是用left join就可以了。。当然其中要有一个字段都能关联上

樱花落人离去 2021-11-26 03:28:26

你不如贴各个表有哪些字段,然后直接说你要查什么,看你这需求就没欲望往下看。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文