把这几张表的数据放在一起,怎么实现这条sql语句
把这几张表的数据放在一起,怎么实现这条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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
神马数据库?
如果是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
这个是用left join就可以了。。当然其中要有一个字段都能关联上
你不如贴各个表有哪些字段,然后直接说你要查什么,看你这需求就没欲望往下看。