DB2学习
1.为了使用ORG_ID,由于OCRM_F_MM_MKT_PLAN a 没有ORG_ID,但是OCRM_F_MM_EXECUTE_INST_DESC d 表里面有,可以使a表连接b表,创建临时表t。
select t.PLAN_S AS MARKET_PLAN_COUNT,t.SUM_PLAN AS PLAN_ACC_COUNT
from (select count(a.MKT_PLAN_STAT) as PLAN_S,sum(case when a.MKT_PLAN_STAT='3' then 1 else 0 end) as SUM_PLAN from OCRM_F_MM_MKT_PLAN a left join OCRM_F_MM_EXECUTE_INST_DESC d on (d.PLAN_ID=a.PLAN_ID))t;
2.
select f.ORG_ID,f.ORG_NAME,t.MARKET_PLAN_COUNT,t.PLAN_ACC_PER,t.PLAN_ACC_COUNT,
b.MARKET_ACT_COUNT,b.ACT_ACC_COUNT,b.ACT_ACC_PER,c.OPPOR_COUNT,
c.OPPOR_ACC_COUNT,c.OPPOR_ACC_PER
from( select d.org_id,count(a.MKT_PLAN_STAT) as MARKET_PLAN_COUNT,
sum(case when a.MKT_PLAN_STAT='3' then 1 else 0 end) as PLAN_ACC_COUNT,
ROUND(CAST(sum(case when a.MKT_PLAN_STAT='3' then 1 else 0 end) AS DOUBLE) / count(a.MKT_PLAN_STAT)*100,4) as PLAN_ACC_PER
from OCRM_F_MM_MKT_PLAN a left join OCRM_F_MM_EXECUTE_INST_DESC d on (d.PLAN_ID=a.PLAN_ID) group by org_id)t
left join (select CREATE_ORG,count( MKT_ACTI_STAT) as MARKET_ACT_COUNT,sum(case when MKT_ACTI_STAT='4' then 1 else 0 end) AS ACT_ACC_COUNT,
ROUND( sum(case when MKT_ACTI_STAT='4' then 1 else 0 end)/count( MKT_ACTI_STAT)*100,4) as ACT_ACC_PER
from OCRM_F_MK_MKT_ACTIVITY group by CREATE_ORG) b on (t.ORG_ID=b.CREATE_ORG)
left join
(
select CREATE_ORG_ID, count(OPPOR_STAT) as OPPOR_COUNT, sum(case when OPPOR_STAT=7 then 1 else 0 end) + sum(case when OPPOR_STAT= 8 then 1 else 0 end) AS OPPOR_ACC_COUNT,
ROUND(CAST( ( sum(case when OPPOR_STAT=7 then 1 else 0 end) + sum(case when OPPOR_STAT= 8 then 1 else 0 end)) AS DOUBLE)/count(OPPOR_STAT) *100,4)as OPPOR_ACC_PER from OCRM_F_MM_MKT_BUSI_OPPOR group by CREATE_ORG_ID) c on (b.CREATE_ORG=c.CREATE_ORG_ID)
left join ADMIN_AUTH_ORG f on (c.CREATE_ORG_ID=f.ORG_ID)
3.统计状态为3,3代表成功的,把3看做1,然后累加1,最后得到表里面有多少个3
select count(a.MKT_PLAN_STAT) as MARKET_PLAN_COUNT, sum(case when a.MKT_PLAN_STAT='3' then 1 else 0 end) as PLAN_ACC_COUNT from OCRM_F_MM_MKT_PLAN a;
4.统计查找客户经理名称,编号,这个客户经理营销计划数量,完成数量,完成率以及营销活动数量,完成数量,完成率以及商机数量,完成数量,完成率,以及这个客户经理的所属机构,机构号。
select
f.CUST_MANAGER_ID,f.CUST_MANAGER_NAME,
t1.MARKET_PLAN_COUNT,t1.PLAN_ACC_COUNT,t1.PLAN_ACC_PER,
t2.MARKET_ACT_COUNT,t2.ACT_ACC_COUNT,t2.ACT_ACC_PER,
t3.OPPOR_COUNT,t3.OPPOR_ACC_COUNT,t3.OPPOR_ACC_PER,
g.ORG_ID,g.ORG_NAME
from (
SELECT
b.EXECUTOR,
COUNT(a.MKT_PLAN_STAT) AS MARKET_PLAN_COUNT,
SUM(
CASE
WHEN a.MKT_PLAN_STAT='3'
THEN 1
ELSE 0
END) AS PLAN_ACC_COUNT,
ROUND( CAST(SUM(
CASE
WHEN a.MKT_PLAN_STAT='3'
THEN 1
ELSE 0
END) AS DOUBLE) / COUNT(a.MKT_PLAN_STAT)*100,4) AS PLAN_ACC_PER
FROM
OCRM_F_MM_MKT_PLAN a
LEFT JOIN OCRM_F_MM_PLAN_CUST b
ON
(
b.PLAN_ID=a.PLAN_ID
)
GROUP BY
EXECUTOR ) t1
left join
( SELECT
d.HOST_MGR_ID,
COUNT( MKT_ACTI_STAT) AS MARKET_ACT_COUNT,
SUM(
CASE
WHEN MKT_ACTI_STAT='4'
THEN 1
ELSE 0
END) AS ACT_ACC_COUNT,
ROUND( SUM(
CASE
WHEN MKT_ACTI_STAT='4'
THEN 1
ELSE 0
END)/COUNT( MKT_ACTI_STAT)*100,4) AS ACT_ACC_PER
FROM
OCRM_F_MK_MKT_ACTIVITY c left join OCRM_F_MK_ACTI_CUSTOMER d on(c.MKT_ACTI_ID=d.MKT_ACTI_ID)
GROUP BY
d.HOST_MGR_ID) t2 on (t1.EXECUTOR=t2.HOST_MGR_ID)
left join
( SELECT
e.CREATER_ID,
COUNT(OPPOR_STAT) AS OPPOR_COUNT,
SUM(
CASE
WHEN OPPOR_STAT=7
THEN 1
ELSE 0
END) + SUM(
CASE
WHEN OPPOR_STAT= 8
THEN 1
ELSE 0
END) AS OPPOR_ACC_COUNT,
ROUND(CAST( ( SUM(
CASE
WHEN OPPOR_STAT=7
THEN 1
ELSE 0
END) + SUM(
CASE
WHEN OPPOR_STAT= 8
THEN 1
ELSE 0
END)) AS DOUBLE)/COUNT(OPPOR_STAT) *100,4)AS OPPOR_ACC_PER
FROM
OCRM_F_MM_MKT_BUSI_OPPOR e
GROUP BY
e.CREATER_ID) t3 on (t2.HOST_MGR_ID=t3.CREATER_ID)
left join
OCRM_F_CM_CUST_MGR_INFO f on (t3.CREATER_ID=f.CUST_MANAGER_ID)
left join ADMIN_AUTH_ORG g on (f.AFFI_INST_ID=g.ORG_ID)
DB2学习的更多相关文章
- db2学习笔记
a.服务端安装 v11.1_win64_expc.zip 官网下载 b.客户端安装 Toad for DB2 Freeware 6.1 百度找找 .建数据库 create database HRA_G ...
- DB2 学习--(1)--安装教程
db2 linux 安装部署 1 解压文件 tar -zxvf db2_v101_linuxx64_expc.tar.gz 2 切换路径 cd expc/ 3 启动安装程序 ./db2_install ...
- DB2学习总结(1)——DB2数据库基础入门
DB2的特性 完全Web使能的:可以利用HTTP来发送询问给服务器. 高度可缩放和可靠:高负荷时可利用多处理器和大内存,可以跨服务器地分布数据库和数据负荷:能够以最小的数据丢失快速地恢复,提供多种备份 ...
- DB2学习笔记备忘 2018.5.9
DB2安装的时候选择了和系统用户一致的选项,然后登陆的时候,连接的时候输入的就是计算机用户的用户名和密码. 1.3 DB2数据库体系结构 系统 一个系统表示DB2的一个安装.在一个由很多及其组成的网络 ...
- db2学习笔记--数据类型对表的影响
创建表的时为列选择合适的数据类型,可以提高数据库性能. 1.选择合适的数据类型,避免出现数据类型转换.例如日期,有人使用字符串来存放日期.时间戳,最后我们还要在程序中使用to_date做数据类型转换, ...
- DB2数据库常用命令数据库学习
DB2数据库常用命令数据库学习你可以用 get snapshot for locks on XXX 看是那个表锁了,再从相关的操作去查原因吧 db2pd -d 库名 -locks和db2pd -d 库 ...
- 学习笔记之DB2 9 Fundamentals 730
Sequence中cache的影响,每新建一个连接,next value值增加increment * cache.如果加上order,则会按顺序生成值. increment cache ; Conne ...
- DB2的基础指令 学习笔记
=======DB2基础指令======= 1.打开数据库db2 connect to 数据库名;2.查看数据库中有哪些表db2 list tables ;3.查看数据库中的表结构db2 descri ...
- DB2导入导出 学习笔记
db2pd -osinfodb2mtrk -i -d (for aix)db2 get dbm cfg show detaildb2 get db cfg show detaildb2 get sna ...
随机推荐
- hdu 1277 全文检索
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1277 全文检索 Description 我们大家经常用google检索信息,但是检索信息的程序是很困难 ...
- asp.net实现手机号码归属地查询
protected void Button1_Click(object sender, EventArgs e) { if (Regex.IsMatch(TextB ...
- Android开发随笔之ScrollView嵌套GridView[ 转]
今天在开发中用到了需要ScrollView嵌套GridView的情况,由于这两款控件都自带滚动条,当他们碰到一起的时候便会出问题,即GridView会显示不全,为了解决这个问题查了N多资料,某个谷歌的 ...
- Linq To SQLite by CRUD
1, 希望使用linqtoSQLite 来对数据库实现CRUD, 开发环境 VS2013, 1.1 在网上找到了 LINQ to DB T4 Models, 配置参考网址链接: http://www. ...
- 关于sqlserver身份登录失败的解决方法
前几天写程序需要用到数据库,下载了一个用用,出现了不少的小问题(都怪我的32bit不争气的笔记本),有问题不要怕,至少证明我们在思考解决方案.废话不说了,直接上正题. Sqlserver有两种登陆方式 ...
- 关于使用regsvr32命令注册ActiveX控件失败的解决办法
昨天小编也遇到这样问题,步骤一切都对,没有错误,但是每次在命令行下输入的时候,都会弹出一个对话框: 最后我发现是存放ActiveX控件的路径中带有中文文件名字所导致,所以导致的错误,我们将所在路径下的 ...
- android listview和button,ImageButton等有事件的控件的总结
public ImageButton(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defSty ...
- Ruby 多线程探索实践与归纳总结
Ruby 多线程 每个正在系统上运行的程序都是一个进程.每个进程包含一到多个线程. 线程是程序中一个单一的顺序控制流程,在单个程序中同时运行多个线程完成不同的工作,称为多线程. Ruby 中我们可以通 ...
- Log4j2 配置笔记(Eclipse+maven+SpringMVC)
Log4j2相关介绍可以百度看下,这里只注重配置Log4j2 能够马上跑起来: 1.pom.xml文件中添加Log4j2的相关Maven配置信息 <!-- log4j2 --> <d ...
- Jquery方法的应用
<body> <div id="one"><span>one</span></div><div class=&qu ...