重置聚合客户表.sql 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. --创建聚合后的客户视图
  2. IF EXISTS (SELECT * FROM sys.views WHERE object_id = OBJECT_ID(N'[dbo].[Vw_AggregationCustomer]'))
  3. DROP VIEW [dbo].[Vw_AggregationCustomer]
  4. GO
  5. CREATE VIEW [dbo].[Vw_AggregationCustomer]
  6. as
  7. with t as(
  8. select
  9. GM_CustomerGroupID
  10. ,CONVERT(varchar(200),dbo.FunTrim(dbo.AggregateString([Cus_Name]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')
  11. +'/'+ dbo.AggregateString([Cus_Name]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}<>{$$}本人{$$}s'),'/')) as Cus_Name
  12. --,CONVERT(varchar(200),dbo.AggregateString([Cus_Name]+'{$$}/')) as Cus_Name
  13. ,CONVERT(varchar(200),dbo.FunTrim(dbo.AggregateString([Cus_Name_py]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')
  14. +'/'+ dbo.AggregateString([Cus_Name_py]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}<>{$$}本人{$$}s'),'/')) as Cus_Name_py
  15. -- ,CONVERT(varchar(200),dbo.AggregateString([Cus_Name_py]+'{$$}/')) as Cus_Name_py
  16. ,CONVERT(varchar(200),dbo.FunTrim(dbo.AggregateString([Cus_Sex_cs]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')
  17. +'/'+ dbo.AggregateString([Cus_Sex_cs]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}<>{$$}本人{$$}s'),'/')) as Cus_Sex_cs
  18. -- ,CONVERT(varchar(200),dbo.AggregateString([Cus_Sex_cs]+'{$$}/{where}'+CONVERT(varchar(1),[GM_ProtagonistCustomer])+'{$$}={$$}1{$$}i')) as Cus_Sex_cs
  19. ,CONVERT(varchar(200),dbo.FunTrim(dbo.AggregateString([Cus_Telephone]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')
  20. +'/'+ dbo.AggregateString([Cus_Telephone]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}<>{$$}本人{$$}s'),'/')) as Cus_Telephone
  21. --,CONVERT(varchar(200),dbo.AggregateString([Cus_Telephone]+'{$$}/')) as Cus_Telephone
  22. --地区
  23. ,CONVERT(varchar(200),dbo.FunTrim(dbo.AggregateString([Cus_Region]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')
  24. +'/'+ dbo.AggregateString([Cus_Region]+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}<>{$$}本人{$$}s'),'/')) as Cus_Region
  25. --,CONVERT(varchar(200),dbo.AggregateString([Cus_Region]+'{$$}/')) as Cus_Region
  26. --年龄字符串
  27. ,CONVERT(varchar(200),dbo.AggregateString(CONVERT(varchar(10),[Age_String])+'{$$}/{where}'+CONVERT(varchar(1),[GM_ProtagonistCustomer])+'{$$}={$$}1{$$}i')) as Age_String
  28. --儿童年龄天数 int 型
  29. ,CONVERT(int,dbo.AggregateString(CONVERT(varchar(10),[Age_Day])+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')) as Age_Day
  30. --儿童年龄岁数 int 型
  31. ,CONVERT(int,dbo.AggregateString(CONVERT(varchar(10),[Age_Year])+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')) as Age_Year
  32. --儿童生日或主联系人生日 统一转为公历
  33. ,CONVERT(datetime,dbo.AggregateString(CONVERT(varchar(10),[GregorianCalendar_Birthday])+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')) as GregorianCalendar_Birthday
  34. --儿童当前年生日日期或主联系人当前年生日日期 统一转为公历
  35. ,CONVERT(datetime,dbo.AggregateString(CONVERT(varchar(10),[GregorianCalendar_NowYearBirthday])+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')) as GregorianCalendar_NowYearBirthday
  36. --主联系人婚期 统一转为公历
  37. ,CONVERT(datetime,dbo.AggregateString(CONVERT(varchar(10),[GregorianCalendar_DayForMarriage])+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')) as GregorianCalendar_DayForMarriage
  38. --主联系人当前年婚期日期 统一转为公历
  39. ,CONVERT(datetime,dbo.AggregateString(CONVERT(varchar(10),[GregorianCalendar_NowYearDayForMarriage])+'{$$}/{where}'+CONVERT(varchar(5),[GM_Relation])+'{$$}={$$}本人{$$}s')) as GregorianCalendar_NowYearDayForMarriage
  40. --以下是主要联系人
  41. ,CONVERT(varchar(200),dbo.AggregateString([Cus_CustomerNumber]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_CustomerNumber
  42. ,CONVERT(varchar(200),dbo.AggregateString([Cus_Name]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_Name
  43. ,CONVERT(varchar(200),dbo.AggregateString([Cus_Name_py]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_Name_py
  44. ,CONVERT(varchar(200),dbo.AggregateString([Cus_Sex_cs]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_Sex_cs
  45. ,CONVERT(varchar(200),dbo.AggregateString([Cus_Telephone]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_Telephone
  46. --主要联系人微信号
  47. ,CONVERT(varchar(200),dbo.AggregateString([Cus_MicroSignal]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_MicroSignal
  48. ,CONVERT(varchar(200),dbo.AggregateString([Cus_QQ]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_QQ
  49. --主要联系人地区
  50. ,CONVERT(varchar(200),dbo.AggregateString([Cus_Region]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i')) as M_Cus_Region
  51. --主要联系人地址
  52. ,dbo.AggregateString([Cus_Address]+'{$$}/{where}'+CONVERT(varchar(1),[GM_Master])+'{$$}={$$}1{$$}i') as M_Cus_Address
  53. --客户组中成员个数
  54. ,count(Cus_CustomerNumber) as Ord_ViceOrderCount
  55. from
  56. dbo.View_CustomerGroupMembersAndErpCustomer
  57. group by GM_CustomerGroupID
  58. )
  59. select
  60. [tb_ErpCustomerGroup].id
  61. ,[GP_OrderNumber]
  62. ,[GP_CustomerGroupID]
  63. ,[GP_GroupType]
  64. ,[GP_CustomerType]
  65. ,[GP_CustomerStatus]
  66. ,[GP_LossReason]
  67. ,[GP_DegreeOfIntent]
  68. ,[GP_CustomerSource]
  69. ,GP_CreateDatetime
  70. ,GP_UpdateDatetime
  71. ,GP_ISIntentionCustomer
  72. ,GP_ReminderTime
  73. ,[GP_IntroducerCustomerID],t.*
  74. ,[dbo].[Vw_ErpMemberCardSimpleInfo].[Mc_CradNumber]
  75. ,[dbo].[Vw_ErpMemberCardSimpleInfo].[Mc_CardType]
  76. from
  77. [tb_ErpCustomerGroup]
  78. left join
  79. t
  80. on [tb_ErpCustomerGroup].[GP_CustomerGroupID]=t.[GM_CustomerGroupID]
  81. left join
  82. [dbo].[Vw_ErpMemberCardSimpleInfo]
  83. on t.M_Cus_CustomerNumber=[dbo].[Vw_ErpMemberCardSimpleInfo].[Mc_CustomerNumber]
  84. GO
  85. --根据聚合后的客户视图创建聚合后的客户临时表
  86. IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[tempTB_AggregationCustomer]'))
  87. DROP table [dbo].[tempTB_AggregationCustomer]
  88. GO
  89. select * into tempTB_AggregationCustomer from [Vw_AggregationCustomer]
  90. go
  91. --唯一索引
  92. CREATE UNIQUE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_GP_CustomerGroupID] ON [dbo].[tempTB_AggregationCustomer]
  93. (
  94. [GP_CustomerGroupID] desc
  95. )
  96. --索引
  97. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_GP_OrderNumber] ON [dbo].[tempTB_AggregationCustomer]
  98. (
  99. [GP_OrderNumber] desc
  100. )
  101. go
  102. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_Cus_Name] ON [dbo].[tempTB_AggregationCustomer]
  103. (
  104. [Cus_Name] desc
  105. )
  106. go
  107. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_Cus_Name_py] ON [dbo].[tempTB_AggregationCustomer]
  108. (
  109. Cus_Name_py desc
  110. )
  111. go
  112. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_Cus_Telephone] ON [dbo].[tempTB_AggregationCustomer]
  113. (
  114. Cus_Telephone desc
  115. )
  116. go
  117. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_GP_CustomerSource] ON [dbo].[tempTB_AggregationCustomer]
  118. (
  119. [GP_CustomerSource] desc
  120. )
  121. go
  122. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_M_Cus_Name] ON [dbo].[tempTB_AggregationCustomer]
  123. (
  124. [M_Cus_Name] desc
  125. )
  126. go
  127. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_M_Cus_Name_py] ON [dbo].[tempTB_AggregationCustomer]
  128. (
  129. M_Cus_Name_py desc
  130. )
  131. go
  132. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_M_Cus_Telephone] ON [dbo].[tempTB_AggregationCustomer]
  133. (
  134. M_Cus_Telephone desc
  135. )
  136. go
  137. CREATE NONCLUSTERED INDEX [IX_tempTB_AggregationCustomer_Mc_CradNumber] ON [dbo].[tempTB_AggregationCustomer]
  138. (
  139. Mc_CradNumber desc
  140. )
  141. go
  142. --创建视图 dbo.tempTB_AggregationCustomer 表的Vw_GroupByAggregationCustomer视图
  143. IF EXISTS (SELECT * FROM sys.views WHERE object_id = OBJECT_ID(N'[dbo].[Vw_GroupByAggregationCustomer]'))
  144. DROP VIEW [dbo].[Vw_GroupByAggregationCustomer]
  145. GO
  146. CREATE VIEW [Vw_GroupByAggregationCustomer]
  147. AS
  148. with t as(
  149. SELECT
  150. max(GP_CustomerGroupID) as GP_CustomerGroupID
  151. from tempTB_AggregationCustomer
  152. group by Cus_Name,M_Cus_CustomerNumber
  153. )
  154. select * from tempTB_AggregationCustomer
  155. where GP_CustomerGroupID in (select GP_CustomerGroupID from t)
  156. go
  157. IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[tempTB_GroupByAggregationCustomer]'))
  158. DROP table [dbo].[tempTB_GroupByAggregationCustomer]
  159. GO
  160. select * into tempTB_GroupByAggregationCustomer from [Vw_GroupByAggregationCustomer]
  161. go
  162. --唯一索引
  163. CREATE UNIQUE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_GP_CustomerGroupID] ON [dbo].[tempTB_GroupByAggregationCustomer]
  164. (
  165. [GP_CustomerGroupID] desc
  166. )
  167. --索引
  168. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_GP_OrderNumber] ON [dbo].[tempTB_GroupByAggregationCustomer]
  169. (
  170. [GP_OrderNumber] desc
  171. )
  172. go
  173. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_Cus_Name] ON [dbo].[tempTB_GroupByAggregationCustomer]
  174. (
  175. [Cus_Name] desc
  176. )
  177. go
  178. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_Cus_Name_py] ON [dbo].[tempTB_GroupByAggregationCustomer]
  179. (
  180. Cus_Name_py desc
  181. )
  182. go
  183. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_Cus_Telephone] ON [dbo].[tempTB_GroupByAggregationCustomer]
  184. (
  185. Cus_Telephone desc
  186. )
  187. go
  188. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_GP_CustomerSource] ON [dbo].[tempTB_GroupByAggregationCustomer]
  189. (
  190. [GP_CustomerSource] desc
  191. )
  192. go
  193. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_M_Cus_Name] ON [dbo].[tempTB_GroupByAggregationCustomer]
  194. (
  195. [M_Cus_Name] desc
  196. )
  197. go
  198. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_M_Cus_Name_py] ON [dbo].[tempTB_GroupByAggregationCustomer]
  199. (
  200. M_Cus_Name_py desc
  201. )
  202. go
  203. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_M_Cus_Telephone] ON [dbo].[tempTB_GroupByAggregationCustomer]
  204. (
  205. M_Cus_Telephone desc
  206. )
  207. go
  208. CREATE NONCLUSTERED INDEX [IX_tempTB_GroupByAggregationCustomer_Mc_CradNumber] ON [dbo].[tempTB_GroupByAggregationCustomer]
  209. (
  210. Mc_CradNumber desc
  211. )
  212. go