保单信息存储过程.sql 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. CREATE OR REPLACE PROCEDURE shanglifeecif.init_insurancearrangement() -- 创建主存储过程
  2. IS
  3. BEGIN
  4. --根据policy_information 更新保单表
  5. shanglifeecif.init_insurancearrangement_policy_information();
  6. --根据health_insurance_listing 更新相关字段
  7. shanglifeecif.up_insurancearrangement_health_insurance_listing();
  8. --其他标的字段 更新
  9. shanglifeecif.up_insurancearrangement_other();
  10. END;
  11. /
  12. CREATE OR REPLACE PROCEDURE shanglifeecif.init_insurancearrangement_policy_information() -- 创建主存储过程
  13. IS
  14. BEGIN
  15. INSERT INTO shanglifeecif.insurancearrangement(
  16. iaid ,--'保单ID',
  17. policyno ,-- '保险单号 INSURANCEINFO.CONTNO',
  18. pindate ,-- '起保日期 POLICY_INFORMATION.CVALIDATE',
  19. pmdate ,-- '终保日期 POLICY_INFORMATION.ENDDATE',
  20. norenewal ,-- '续保次数 POLICY_INFORMATION.PAYCOUNT',
  21. payment ,-- '缴费方式 POLICY_INFORMATION.PAYINTV',
  22. applicantscustid ,-- '投保人 上游客户号,再找到individualid',
  23. appname ,-- '投保人名称 POLICY_INFORMATION.NAME',
  24. appcertid ,-- '投保人证件号码 POLICY_INFORMATION.IDNO',
  25. insuredscustid ,-- '主被保险人 游客户号',
  26. insname ,-- '主被保险人名称 POLICY_INFORMATION.INSUREDNAME',
  27. inscertid ,-- '主被保险人证件号码 POLICY_INFORMATION.INSUREDIDNO',
  28. productid ,-- '险种代码 POLICY_INFORMATION.RISKCODE',
  29. policybelong ,-- '业绩归属 POLICY_INFORMATION.SALECOM',
  30. payendyear ,-- '缴费年期 POLICY_INFORMATION.PAYENDYEAR',
  31. agrmntage ,--保险期限
  32. created_by ,-- '创建人',
  33. created_time -- '创建时间',
  34. )
  35. SELECT
  36. row_number()over(),
  37. CONTNO,--policyno ,-- '保险单号 INSURANCEINFO.CONTNO',
  38. CVALIDATE,--pindate ,-- '起保日期 POLICY_INFORMATION.CVALIDATE',
  39. ENDDATE,--pmdate ,-- '终保日期 POLICY_INFORMATION.ENDDATE',
  40. PAYCOUNT,--norenewal ,-- '续保次数 POLICY_INFORMATION.PAYCOUNT',
  41. PAYINTV,--payment ,-- '缴费方式 POLICY_INFORMATION.PAYINTV',
  42. CUSTOMERNO,--applicantid ,-- '投保人 根据POLICY_INFORMATION.CUSTOMERNO关联individual上游客户号,再找到individualid',
  43. NAME,--appname ,-- '投保人名称 POLICY_INFORMATION.NAME',
  44. IDNO,--appcertid ,-- '投保人证件号码 POLICY_INFORMATION.IDNO',
  45. insuredno,--insuredid ,-- '主被保险人 insuredno',
  46. INSUREDNAME,--insname ,-- '主被保险人名称 POLICY_INFORMATION.INSUREDNAME',
  47. INSUREDIDNO,--inscertid ,-- '主被保险人证件号码 POLICY_INFORMATION.INSUREDIDNO',
  48. RISKCODE,--productid ,-- '险种代码 POLICY_INFORMATION.RISKCODE',
  49. SALECOM,--policybelong ,-- '业绩归属 POLICY_INFORMATION.SALECOM',
  50. PAYENDYEAR,--payendyear ,-- '缴费年期 POLICY_INFORMATION.PAYENDYEAR',
  51. case
  52. when security ='终身' then 42720
  53. when security = '至100周岁' then 36500
  54. when security = '至80周岁' then 29200
  55. when security = '70年' then 25550
  56. when security = '至70周岁' then 25550
  57. when security = '至65周岁' then 23725
  58. when security = '至60周岁' then 21900
  59. when security = '30年' then 10950
  60. when security = '20年' then 7300
  61. when security = '10年' then 3650
  62. when security = '6年' then 2190
  63. when security = '5年' then 1825
  64. when security = '1年' then 365
  65. when security = '180天' then 180
  66. when security = '6月' then 180
  67. when security = '90天' then 90
  68. when security = '3月' then 90
  69. when security = '1月' then 30
  70. when security = '30天' then 30
  71. when security = '15天' then 15
  72. when security = '7天' then 7
  73. end,
  74. 'admin',
  75. sysdate()
  76. FROM shanghailifeecif.policy_information
  77. --更新险种大类
  78. /*UPDATE shanglifeecif.insurancearrangement a SET (
  79. risk_categories,
  80. risk_categories_name
  81. ) = (
  82. select
  83. b.kindcode,
  84. (CASE b.kindcode
  85. WHEN 'A' THEN '意外伤害险'
  86. WHEN 'U' THEN '万能保险'
  87. WHEN 'R' THEN '年金保险'
  88. WHEN 'S' THEN '重疾保险'
  89. WHEN 'L' THEN '人寿保险'
  90. WHEN 'H' THEN '健康险'
  91. END) AS kindname
  92. from lmriskapp b WHERE a.productid = b.riskcode
  93. ) WHERE 1=1;*/;
  94. --更新投保人和被保人id 因为 scustid有重复所以需要去下重
  95. UPDATE shanglifeecif.insurancearrangement a SET (
  96. applicantid --'投保人ID',
  97. ) = (
  98. select
  99. c.indid
  100. from (
  101. select
  102. row_number()over(PARTITION BY b.scustid) rn,
  103. b.indid,
  104. b.scustid
  105. from shanglifeecif.individual b
  106. ) c
  107. WHERE c.scustid = a.applicantscustid and c.rn=1
  108. ) WHERE 1=1 ;
  109. UPDATE shanglifeecif.insurancearrangement a SET (
  110. insuredid --'投保人ID',
  111. ) = (
  112. select
  113. c.indid
  114. from (
  115. select
  116. row_number()over(PARTITION BY b.scustid) rn,
  117. b.indid,
  118. b.scustid
  119. from shanglifeecif.individual b
  120. ) c
  121. WHERE c.scustid = a.insuredscustid and c.rn=1
  122. ) WHERE 1=1 ;
  123. --更新INSURANCEINFO 表中的信息
  124. UPDATE shanglifeecif.insurancearrangement a SET (
  125. pano ,-- '投保单号 INSURANCEINFO.PRTNO',
  126. pisdate ,-- '签单日期 INSURANCEINFO.SIGNDATE',
  127. padate ,-- '投保日期 INSURANCEINFO.POLAPPLYDATE',
  128. policystate ,--INSURANCEINFO,appflag
  129. prem ,-- '总保费 INSURANCEINFO.PREM',
  130. productname ,-- '险种名称 INSURANCEINFO.RISKNAME'
  131. agentchannel -- '代理渠道 INSURANCEINFO.SELLTYPE',
  132. ) = (
  133. select
  134. PRTNO,--pano ,-- '投保单号 INSURANCEINFO.PRTNO',
  135. SIGNDATE,--pisdate ,-- '签单日期 INSURANCEINFO.SIGNDATE',
  136. POLAPPLYDATE,--padate ,-- '投保日期 INSURANCEINFO.POLAPPLYDATE',
  137. appflag,--policystate ,--INSURANCEINFO,appflag
  138. PREM,--prem ,-- '总保费 INSURANCEINFO.PREM',
  139. RISKNAME,--productname ,-- '险种名称 INSURANCEINFO.RISKNAME'
  140. SELLTYPE--agentchannel ,-- '代理渠道 INSURANCEINFO.SELLTYPE',
  141. from shanghailifeecif.INSURANCEINFO b
  142. where b.contno = a.policyno
  143. ) WHERE 1=1 ;
  144. END;
  145. /
  146. --临时表
  147. CREATE TABLE shanglifeecif.insurancearrangement_health_tmp(
  148. id string,
  149. orderid string DEFAULT NULL COMMENT '用于分组的排序号',
  150. contno string DEFAULT NULL COMMENT '保单号',
  151. AGENTGROUP string DEFAULT NULL COMMENT '承保分公司',--pwcomp ,-- '承保分公司 HEALTH_INSURANCE_LISTING.AGENTGROUPAREA 营业区HEALTH_INSURANCE_LISTING.AGENTGROUP 营业部',
  152. SALECHANNELS string DEFAULT NULL COMMENT '销售渠道',--schannel ,-- '销售渠道 HEALTH_INSURANCE_LISTING.SALECHANNELS 1 2 3 4 5',
  153. AMNT string DEFAULT NULL COMMENT '总保额',--risk ,-- '总保额 HEALTH_INSURANCE_LISTING.AMNT(测试环境中,此表保单数据量较其他表如:POLICY_INFORMATION,INSURANCEINFO 缺少至少一个数据量级)',
  154. AGENTCODE string DEFAULT NULL COMMENT'业务员名称'--spname ,-- '业务员名称 HEALTH_INSURANCE_LISTING.AGENTCODE',
  155. ) COMMENT '保单处理个险承保清单自助分析 数据临时表 '
  156. STORED AS ES
  157. with shard number 10
  158. replication 1;
  159. CREATE OR REPLACE PROCEDURE shanglifeecif.up_insurancearrangement_health_insurance_listing() -- 创建主存储过程
  160. IS
  161. BEGIN
  162. --清空临时表数据
  163. delete from shanglifeecif.insurancearrangement_health_tmp;
  164. --初始化临时表
  165. insert into shanglifeecif.insurancearrangement_health_tmp (
  166. id,
  167. orderid,
  168. contno,
  169. agentgroup,
  170. SALECHANNELS,
  171. AMNT,
  172. AGENTCODE
  173. ) select
  174. row_number()over(),
  175. row_number()over(PARTITION BY contno),
  176. contno,
  177. agentgroup,
  178. SALECHANNELS,
  179. AMNT,
  180. AGENTCODE
  181. from shanghailifeecif.HEALTH_INSURANCE_LISTING
  182. --根据临时表更新insurancearrangement 表
  183. UPDATE shanglifeecif.insurancearrangement a SET (
  184. pwcomp ,-- '承保分公司 HEALTH_INSURANCE_LISTING.AGENTGROUPAREA 营业区HEALTH_INSURANCE_LISTING.AGENTGROUP 营业部',
  185. schannel ,-- '销售渠道 HEALTH_INSURANCE_LISTING.SALECHANNELS 1 2 3 4 5',
  186. risk ,-- '总保额 HEALTH_INSURANCE_LISTING.AMNT(测试环境中,此表保单数据量较其他表如:POLICY_INFORMATION,INSURANCEINFO 缺少至少一个数据量级)',
  187. spname -- '业务员名称 HEALTH_INSURANCE_LISTING.AGENTCODE',
  188. ) = (
  189. select
  190. b.AGENTGROUP,--pwcomp ,-- '承保分公司 HEALTH_INSURANCE_LISTING.AGENTGROUPAREA 营业区HEALTH_INSURANCE_LISTING.AGENTGROUP 营业部',
  191. b.SALECHANNELS,--schannel ,-- '销售渠道 HEALTH_INSURANCE_LISTING.SALECHANNELS 1 2 3 4 5',
  192. b.AMNT,--risk ,-- '总保额 HEALTH_INSURANCE_LISTING.AMNT(测试环境中,此表保单数据量较其他表如:POLICY_INFORMATION,INSURANCEINFO 缺少至少一个数据量级)',
  193. b.AGENTCODE--spname ,-- '业务员名称 HEALTH_INSURANCE_LISTING.AGENTCODE',
  194. from shanglifeecif.insurancearrangement_health_tmp b
  195. where b.contno = a.policyno
  196. and b.orderid = 1
  197. ) WHERE 1=1 ;
  198. END;
  199. /
  200. CREATE OR REPLACE PROCEDURE shanglifeecif.up_insurancearrangement_other() -- 创建主存储过程
  201. IS
  202. BEGIN
  203. UPDATE shanglifeecif.insurancearrangement a SET (
  204. policytype -- '保单类型',
  205. ) = (
  206. select
  207. c.CONTTYPE
  208. from (
  209. select
  210. row_number()over(PARTITION BY b.contno) rn,
  211. b.CONTTYPE,
  212. b.contno
  213. from shanghailifeecif.PERSONAL_INSURANCE b
  214. ) c
  215. WHERE c.contno = a.policyno and c.rn=1
  216. ) WHERE 1=1 ;
  217. UPDATE shanglifeecif.insurancearrangement a SET (
  218. poservice -- '是否保全',
  219. ) = (
  220. SELECT
  221. IF(count(b.CONTNO) >0,1,0)
  222. FROM shanghailifeecif.AUDIT_EDORLIST b
  223. where b.contno = a.policyno
  224. ) WHERE 1=1 ;
  225. UPDATE shanglifeecif.insurancearrangement a SET (
  226. soinsured-- '被保人数',
  227. ) = (
  228. SELECT
  229. PEOPLES3
  230. FROM shanghailifeecif.HEALTH_GROUP_LISTING b
  231. where b.contno = a.policyno
  232. ) WHERE 1=1 ;
  233. END;