参与方事件.sql 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. CREATE TABLE shanghailifeecif.edorinfo(
  2. contno string DEFAULT NULL COMMENT '保单号',
  3. edortype string DEFAULT NULL COMMENT '管理机构',
  4. lppostaladdress string DEFAULT NULL COMMENT '原客户地址',
  5. lcpostaladdress string DEFAULT NULL COMMENT '现客户地址',
  6. lpmobile string DEFAULT NULL COMMENT '原手机号',
  7. lcmobile string DEFAULT NULL COMMENT '现手机号 ',
  8. lpidtype string DEFAULT NULL COMMENT '原证件类型',
  9. lcidtype string DEFAULT NULL COMMENT '现证件类型 ',
  10. lpidno string DEFAULT NULL COMMENT '原证件号码',
  11. lcidno string DEFAULT NULL COMMENT '现证件号码 ',
  12. EDORAPPDATE string DEFAULT NULL COMMENT '保全申请日期',
  13. EDORCVALIDATE string DEFAULT NULL COMMENT '保全生效日期 '
  14. )
  15. COMMENT '保全'
  16. STORED AS csvfile;
  17. CREATE TABLE shanghailifeecif.audit_edorlist(
  18. managecom varchar2(200) DEFAULT NULL COMMENT '管理机构', -- dialect: ORACLE
  19. managename varchar2(200) DEFAULT NULL COMMENT '管理机构名称', -- dialect: ORACLE
  20. salechnl varchar2(200) DEFAULT NULL COMMENT '销售渠道', -- dialect: ORACLE
  21. salechnlname varchar2(64) DEFAULT NULL COMMENT '销售渠道名称', -- dialect: ORACLE
  22. selltype varchar2(64) DEFAULT NULL COMMENT '合作渠道代码', -- dialect: ORACLE
  23. selltypename varchar2(64) DEFAULT NULL COMMENT '合作渠道名称', -- dialect: ORACLE
  24. contno varchar2(200) DEFAULT NULL COMMENT '保单号', -- dialect: ORACLE
  25. riskcodes varchar2(200) DEFAULT NULL COMMENT '险种代码', -- dialect: ORACLE
  26. risknames varchar2(200) DEFAULT NULL COMMENT '险种名称', -- dialect: ORACLE
  27. risktypes varchar2(64) DEFAULT NULL COMMENT '险种类型', -- dialect: ORACLE
  28. signdate timestamp DEFAULT NULL COMMENT '承保日期',
  29. appntname varchar2(200) DEFAULT NULL COMMENT '投保人', -- dialect: ORACLE
  30. prem decimal(10,2) DEFAULT NULL COMMENT '保费',
  31. edorname varchar2(256) DEFAULT NULL COMMENT '保全类型', -- dialect: ORACLE
  32. edoracceptno varchar2(256) DEFAULT NULL COMMENT '保全受理号', -- dialect: ORACLE
  33. edorno varchar2(256) DEFAULT NULL COMMENT '批单号', -- dialect: ORACLE
  34. edorvalidate timestamp DEFAULT NULL COMMENT '保全生效日期',
  35. customerhandleflag varchar2(64) DEFAULT NULL COMMENT '是否亲办', -- dialect: ORACLE
  36. operator varchar2(256) DEFAULT NULL COMMENT '操作人', -- dialect: ORACLE
  37. approveoperator varchar2(256) DEFAULT NULL COMMENT '审批人', -- dialect: ORACLE
  38. getmoney decimal(10,2) DEFAULT NULL COMMENT '保全退补费金额',
  39. cusappdate timestamp DEFAULT NULL COMMENT '客户申请日期',
  40. payyears varchar2(64) DEFAULT NULL COMMENT '缴费年期', -- dialect: ORACLE
  41. agentname varchar2(256) DEFAULT NULL COMMENT '代理人姓名', -- dialect: ORACLE
  42. edorstate varchar2(64) DEFAULT NULL COMMENT '保全状态', -- dialect: ORACLE
  43. ins_time timestamp DEFAULT NULL
  44. )
  45. COMMENT '保全清单';
  46. ======================================================================
  47. =================================目的表结构=================================
  48. ======================================================================
  49. CREATE TABLE PartyTimeLine(
  50. TripID string NOT NULL COMMENT '旅程ID' ,
  51. PartyID string NOT NULL COMMENT '参与方ID' ,
  52. Name string COMMENT '参与方名称' ,
  53. PCertID string COMMENT '参与方证件号码' ,
  54. PPhone string COMMENT '参与方手机' ,
  55. PRole string COMMENT '参与方角色 投保人、被保人、受益人' ,
  56. Scenario string COMMENT '场景 投保 保全 报案 咨询 投诉 其他' ,
  57. SDate DATE COMMENT '发生日期' ,
  58. ThreadID string COMMENT '关联ID 可关联至更详细信息,如保单ID、报案ID等' ,
  59. ParentID string COMMENT '父ID 如报案对应的保单ID' ,
  60. Describe string COMMENT '描述' ,
  61. Channel string COMMENT '来源' ,
  62. EndDate DATE COMMENT '完成日期' ,
  63. CREATED_BY string COMMENT '创建人' ,
  64. CREATED_TIME DATE COMMENT '创建时间' ,
  65. UPDATED_BY string COMMENT '更新人' ,
  66. UPDATED_TIME DATE COMMENT '更新时间'
  67. ) COMMENT '参与方事件 '
  68. STORED AS ES
  69. with shard number 10
  70. replication 1;
  71. ==================================================初始化数据====================================================================
  72. CREATE OR REPLACE PROCEDURE init_partytimeline_main() -- 创建主存储过程
  73. IS
  74. DECLARE
  75. partytimeline_count int
  76. strsql string
  77. BEGIN
  78. --1.从保全清单表中初始化 参与事件
  79. init_insuranceclaimthread_edorlist(partytimeline_count)
  80. partytimeline_count:=partytimeline_count+1;
  81. --2.从保全表中初始化 参与事件
  82. init_insuranceclaimthread_dorinfo(partytimeline_count)
  83. partytimeline_count:=partytimeline_count+1;
  84. -- 用于以后更新时是用的序列
  85. strsql:='
  86. DROP SEQUENCE IF EXISTS globaleTripID_sequence;
  87. CREATE SEQUENCE globaleTripID_sequence
  88. INCREMENT BY 1
  89. START WITH '|| partytimeline_count||'
  90. NOMAXVALUE
  91. NOMINVALUE
  92. NOCYCLE
  93. CACHE 1;
  94. ';
  95. EXECUTE IMMEDIATE strsql
  96. EXCEPTION
  97. WHEN HIVE_EXCEPTION THEN
  98. log_exception('init_partytimeline_main',sqlerrm(),sqlcode())
  99. WHEN Others THEN
  100. log_exception('init_partytimeline_main',sqlerrm(),sqlcode())
  101. END;
  102. /*audit_edorlist 表
  103. managecom varchar2(200) DEFAULT NULL COMMENT '管理机构', -- dialect: ORACLE
  104. managename varchar2(200) DEFAULT NULL COMMENT '管理机构名称', -- dialect: ORACLE
  105. salechnl varchar2(200) DEFAULT NULL COMMENT '销售渠道', -- dialect: ORACLE
  106. salechnlname varchar2(64) DEFAULT NULL COMMENT '销售渠道名称', -- dialect: ORACLE
  107. selltype varchar2(64) DEFAULT NULL COMMENT '合作渠道代码', -- dialect: ORACLE
  108. selltypename varchar2(64) DEFAULT NULL COMMENT '合作渠道名称', -- dialect: ORACLE
  109. contno varchar2(200) DEFAULT NULL COMMENT '保单号', -- dialect: ORACLE
  110. riskcodes varchar2(200) DEFAULT NULL COMMENT '险种代码', -- dialect: ORACLE
  111. risknames varchar2(200) DEFAULT NULL COMMENT '险种名称', -- dialect: ORACLE
  112. risktypes varchar2(64) DEFAULT NULL COMMENT '险种类型', -- dialect: ORACLE
  113. signdate timestamp DEFAULT NULL COMMENT '承保日期',
  114. appntname varchar2(200) DEFAULT NULL COMMENT '投保人', -- dialect: ORACLE
  115. prem decimal(10,2) DEFAULT NULL COMMENT '保费',
  116. edorname varchar2(256) DEFAULT NULL COMMENT '保全类型', -- dialect: ORACLE
  117. edoracceptno varchar2(256) DEFAULT NULL COMMENT '保全受理号', -- dialect: ORACLE
  118. edorno varchar2(256) DEFAULT NULL COMMENT '批单号', -- dialect: ORACLE
  119. edorvalidate timestamp DEFAULT NULL COMMENT '保全生效日期',
  120. customerhandleflag varchar2(64) DEFAULT NULL COMMENT '是否亲办', -- dialect: ORACLE
  121. operator varchar2(256) DEFAULT NULL COMMENT '操作人', -- dialect: ORACLE
  122. approveoperator varchar2(256) DEFAULT NULL COMMENT '审批人', -- dialect: ORACLE
  123. getmoney decimal(10,2) DEFAULT NULL COMMENT '保全退补费金额',
  124. cusappdate timestamp DEFAULT NULL COMMENT '客户申请日期',
  125. payyears varchar2(64) DEFAULT NULL COMMENT '缴费年期', -- dialect: ORACLE
  126. agentname varchar2(256) DEFAULT NULL COMMENT '代理人姓名', -- dialect: ORACLE
  127. edorstate varchar2(64) DEFAULT NULL COMMENT '保全状态', -- dialect: ORACLE
  128. ins_time timestamp DEFAULT NULL
  129. */
  130. CREATE TABLE PartyTimeLine_edor_tmp(
  131. id string,
  132. contno string comment '保单号',
  133. PartyID string COMMENT '参与方ID' ,
  134. appntname string COMMENT '参与方名称' ,
  135. PCertID string COMMENT '参与方证件号码' ,
  136. PPhone string COMMENT '参与方手机' ,
  137. cusappdate DATE COMMENT '客户申请日期' ,
  138. edoracceptno string COMMENT '保全受理号' ,
  139. edorvalidate DATE COMMENT '保全生效日期'
  140. ) COMMENT '参与方保全事件临时表 '
  141. STORED AS ES
  142. with shard number 10
  143. replication 1;
  144. !set plsqlUseSlash true
  145. SET plsql.catch.hive.exception=true;
  146. --set plsql.compile.dml.check.semantic=false; --禁止编译过程对PL/SQL内部语法进行检查。
  147. CREATE OR REPLACE PROCEDURE init_insuranceclaimthread_edorlist(partytimeline_count OUT int)
  148. IS
  149. BEGIN
  150. --初始化临时表
  151. delete from PartyTimeLine_edor_tmp;
  152. insert into PartyTimeLine_edor_tmp(
  153. id,
  154. contno,
  155. appntname,
  156. cusappdate,
  157. edoracceptno,
  158. edorvalidate
  159. )
  160. SELECT
  161. row_number()over(),
  162. contno,
  163. appntname,
  164. cusappdate,
  165. edoracceptno,
  166. edorvalidate
  167. from shanghailifeecif.audit_edorlist;
  168. --更新临时表信息
  169. UPDATE PartyTimeLine_edor_tmp a SET (
  170. PartyID ,-- 参与方ID
  171. PCertID ,-- 参与方证件号码
  172. PPhone
  173. ) = (
  174. select
  175. ApplicantID ,--客户等级
  176. AppCertID ,--贡献度分
  177. AppPhone--家庭加分
  178. from shanglifeecif.InsuranceArrangement b
  179. where b.PolicyNo = a.contno
  180. ) WHERE 1=1 ;
  181. --更新参与方事件表
  182. insert into PartyTimeLine(
  183. TripID,
  184. PartyID, --参与方id
  185. Name,
  186. PCertID,
  187. PPhone,
  188. PRole,
  189. Scenario,
  190. SDate,
  191. ThreadID,
  192. ParentID,
  193. EndDate,
  194. CREATED_BY,
  195. CREATED_TIME
  196. )
  197. SELECT
  198. row_number()over(),
  199. PartyID,
  200. appntname,
  201. PCertID,
  202. PPhone,
  203. '投保人',
  204. '投保',
  205. cusappdate,
  206. edoracceptno,
  207. contno,
  208. edorvalidate,
  209. 'admin',
  210. sysdate
  211. from PartyTimeLine_edor_tmp where PartyID is not null;
  212. --已经存在的数据行数
  213. select count(0) into partytimeline_count from PartyTimeLine
  214. EXCEPTION
  215. WHEN HIVE_EXCEPTION THEN
  216. log_exception('init_insuranceclaimthread_edorlist',sqlerrm(),sqlcode())
  217. WHEN Others THEN
  218. log_exception('init_insuranceclaimthread_edorlist',sqlerrm(),sqlcode())
  219. END;
  220. --------------------------------根据edorinfo更新 保全----------------------------------------
  221. /*
  222. contno string DEFAULT NULL COMMENT '保单号',
  223. edortype string DEFAULT NULL COMMENT '管理机构',
  224. lppostaladdress string DEFAULT NULL COMMENT '原客户地址',
  225. lcpostaladdress string DEFAULT NULL COMMENT '现客户地址',
  226. lpmobile string DEFAULT NULL COMMENT '原手机号',
  227. lcmobile string DEFAULT NULL COMMENT '现手机号 ',
  228. lpidtype string DEFAULT NULL COMMENT '原证件类型',
  229. lcidtype string DEFAULT NULL COMMENT '现证件类型 ',
  230. lpidno string DEFAULT NULL COMMENT '原证件号码',
  231. lcidno string DEFAULT NULL COMMENT '现证件号码 ',
  232. EDORAPPDATE string DEFAULT NULL COMMENT '保全申请日期',
  233. EDORCVALIDATE string DEFAULT NULL COMMENT '保全生效日期 '
  234. */
  235. CREATE OR REPLACE PROCEDURE init_insuranceclaimthread_dorinfo(partytimeline_count OUT int)
  236. IS
  237. BEGIN
  238. --初始化临时表
  239. delete from PartyTimeLine_edor_tmp;
  240. insert into PartyTimeLine_edor_tmp(
  241. id,
  242. contno,
  243. appntname,
  244. cusappdate,
  245. edoracceptno,
  246. edorvalidate
  247. )
  248. SELECT
  249. row_number()over(),
  250. contno,
  251. appntname,
  252. EDORAPPDATE,
  253. edoracceptno,
  254. EDORCVALIDATE
  255. from shanghailifeecif.audit_edorlist;
  256. --更新临时表信息
  257. UPDATE PartyTimeLine_edor_tmp a SET (
  258. PartyID ,-- 参与方ID
  259. PCertID ,-- 参与方证件号码
  260. PPhone
  261. ) = (
  262. select
  263. ApplicantID ,--客户等级
  264. AppCertID ,--贡献度分
  265. AppPhone--家庭加分
  266. from shanglifeecif.InsuranceArrangement b
  267. where b.PolicyNo = a.contno
  268. ) WHERE 1=1 ;
  269. --更新参与方事件表
  270. insert into PartyTimeLine(
  271. TripID,
  272. PartyID, --参与方id
  273. Name,
  274. PCertID,
  275. PPhone,
  276. PRole,
  277. Scenario,
  278. SDate,
  279. ThreadID,
  280. ParentID,
  281. EndDate,
  282. CREATED_BY,
  283. CREATED_TIME
  284. )
  285. SELECT
  286. row_number()over(),
  287. PartyID,
  288. appntname,
  289. PCertID,
  290. PPhone,
  291. '投保人',
  292. '投保',
  293. cusappdate,
  294. edoracceptno,
  295. contno,
  296. edorvalidate,
  297. 'admin',
  298. sysdate
  299. from PartyTimeLine_edor_tmp where PartyID is not null;
  300. --已经存在的数据行数
  301. select count(0) into partytimeline_count from PartyTimeLine
  302. EXCEPTION
  303. WHEN HIVE_EXCEPTION THEN
  304. log_exception('init_insuranceclaimthread_dorinfo',sqlerrm(),sqlcode())
  305. WHEN Others THEN
  306. log_exception('init_insuranceclaimthread_dorinfo',sqlerrm(),sqlcode())
  307. END;
  308. ================================================数据解析============================================================================================
  309. --保全号是唯一的 是不重复的
  310. --从 audit_edorlist 的表中插入的数据为 619006
  311. --有1060个数据 因为查不到保单无法进入数据库
  312. SELECT count(1) FROM audit_edorlist ; --620066
  313. SELECT count(1) FROM (
  314. SELECT contno FROM audit_edorlist GROUP BY contno
  315. ); --根据保单 去重550805
  316. SELECT count(1) FROM (
  317. SELECT contno,cusappdate FROM audit_edorlist GROUP BY contno,cusappdate
  318. );--根据保单和申请时间 去重 591350
  319. SELECT count(1) a,contno FROM audit_edorlist GROUP BY contno,cusappdate ORDER BY a DESC;
  320. --查询重复最多的数据
  321. SELECT * FROM audit_edorlist WHERE contno = '2018020800060078';