contract_allocation.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565
  1. package cygx
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hz_crm_api/models"
  6. "hongze/hz_crm_api/models/company"
  7. "hongze/hz_crm_api/models/cygx"
  8. "hongze/hz_crm_api/services/alarm_msg"
  9. "hongze/hz_crm_api/utils"
  10. "strconv"
  11. "strings"
  12. "time"
  13. )
  14. //
  15. //func init() {
  16. // fmt.Println(GetCompanyContractPermissionNameMapBymapCompamy(map[int]string{6991: "1138"}))
  17. //}
  18. // GetCompanyContractPermissionNameMapBymapCompamy 获取合并之后的合同所对应的权限种类名称
  19. func GetCompanyContractPermissionNameMapBymapCompamy(mapCompamy map[int]string) (mapContractResp map[int]string, err error) {
  20. if len(mapCompamy) == 0 {
  21. return
  22. }
  23. mapContracIdCompanyId := make(map[int]int) //建立合同ID与公司ID的map对应关系
  24. var companyContractIds []int
  25. //var companyContractIdGroup string //多个合同ID
  26. for k, v := range mapCompamy {
  27. //companyContractIdGroup += v + ","
  28. sliceContract := strings.Split(v, ",")
  29. for _, compamyContracId := range sliceContract {
  30. companyContractIdInt, _ := strconv.Atoi(compamyContracId)
  31. mapContracIdCompanyId[companyContractIdInt] = k
  32. companyContractIds = append(companyContractIds, companyContractIdInt)
  33. }
  34. }
  35. // 获取单个合同所对应的权限名称
  36. contractPermissionNameMap, e := GetCompanyContractPermissionNameMapById(companyContractIds)
  37. if e != nil {
  38. err = errors.New("GetCompanyContractPermissionNameMapById, Err: " + e.Error())
  39. return
  40. }
  41. mapContractResp = make(map[int]string, 0)
  42. for k, v := range mapCompamy {
  43. sliceContract := strings.Split(v, ",")
  44. for _, compamyContracId := range sliceContract {
  45. companyContractIdInt, _ := strconv.Atoi(compamyContracId)
  46. for k2, v2 := range contractPermissionNameMap {
  47. if companyContractIdInt == k2 {
  48. mapContractResp[k] += v2 + ","
  49. }
  50. }
  51. }
  52. }
  53. for k, v := range mapContractResp {
  54. mapContractResp[k] = strings.TrimRight(v, ",")
  55. }
  56. return
  57. }
  58. // GetCompanyContractPermissionNameMapById 获取合并之后的合同所对应的权限种类名称
  59. func GetCompanyContractPermissionNameMapById(companyContractIds []int) (mapContractResp map[int]string, err error) {
  60. //return
  61. lenArr := len(companyContractIds)
  62. if lenArr == 0 {
  63. return
  64. }
  65. var condition string
  66. var pars []interface{}
  67. condition += " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ")"
  68. pars = append(pars, companyContractIds)
  69. companyContractList, e := company.GetCompanyContractList(condition, pars)
  70. if e != nil && e.Error() != utils.ErrNoRow() {
  71. err = errors.New("GetCompanyContractList, Err: " + e.Error())
  72. return
  73. }
  74. permissionList, e := models.GetChartPermissionList()
  75. if e != nil && e.Error() != utils.ErrNoRow() {
  76. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  77. return
  78. }
  79. mappermissionName := make(map[int]string)
  80. for _, v := range permissionList {
  81. if v.ProductId == 2 {
  82. mappermissionName[v.ChartPermissionId] = v.Remark
  83. }
  84. }
  85. mapContractIdPerssion := make(map[int]string) //单个合同ID所对应的套餐或者权限名称
  86. for _, v := range companyContractList {
  87. if v.RaiPackageType == 1 {
  88. mapContractIdPerssion[v.CompanyContractId] = "70w套餐"
  89. }
  90. if v.RaiPackageType == 2 {
  91. mapContractIdPerssion[v.CompanyContractId] = "45w套餐"
  92. }
  93. }
  94. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  95. if e != nil && e.Error() != utils.ErrNoRow() {
  96. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  97. return
  98. }
  99. mapIsUpgrade := make(map[string]bool) //合同ID对应的行业是否有升级
  100. for _, v := range companyContractPermissionList {
  101. //如果开通的不是整个套餐,那么就做单独的子权限处理
  102. if strings.Count(mapContractIdPerssion[(v.CompanyContractId)], "w套餐") == 0 {
  103. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  104. if v.ExpensiveYx == 1 {
  105. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w),"
  106. } else if v.ExpensiveYx == 2 {
  107. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(10w),"
  108. } else {
  109. mapContractIdPerssion[(v.CompanyContractId)] += utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w),"
  110. }
  111. } else {
  112. mapContractIdPerssion[(v.CompanyContractId)] += mappermissionName[v.ChartPermissionId] + ","
  113. if v.IsUpgrade == 1 {
  114. //合同ID,权限名称形成唯一的主键索引
  115. perssionName := mappermissionName[v.ChartPermissionId]
  116. perssionName = strings.Replace(perssionName, "(客观)", "", -1)
  117. perssionName = strings.Replace(perssionName, "(主观)", "", -1)
  118. mapIsUpgrade[fmt.Sprint(v.CompanyContractId, "perssionName", perssionName)] = true
  119. }
  120. }
  121. } else {
  122. if v.ChartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  123. if v.ExpensiveYx == 1 {
  124. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(5w)"
  125. } else {
  126. mapContractIdPerssion[(v.CompanyContractId)] += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN + "(3w)"
  127. }
  128. }
  129. }
  130. }
  131. //合并客观权限
  132. for k, v := range mapContractIdPerssion {
  133. perssionName := v
  134. if strings.Count(v, utils.YI_YAO_NAME) == 2 {
  135. perssionName = strings.Replace(perssionName, "医药(主观)", "医药", -1)
  136. perssionName = strings.Replace(perssionName, "医药(客观)", "", -1)
  137. }
  138. if strings.Count(v, utils.XIAO_FEI_NAME) == 2 {
  139. perssionName = strings.Replace(perssionName, "消费(主观)", "消费", -1)
  140. perssionName = strings.Replace(perssionName, "消费(客观)", "", -1)
  141. }
  142. if strings.Count(v, utils.KE_JI_NAME) == 2 {
  143. perssionName = strings.Replace(perssionName, "科技(主观)", "科技", -1)
  144. perssionName = strings.Replace(perssionName, "科技(客观)", "", -1)
  145. }
  146. if strings.Count(v, utils.ZHI_ZAO_NAME) == 2 {
  147. perssionName = strings.Replace(perssionName, "智造(主观)", "智造", -1)
  148. perssionName = strings.Replace(perssionName, "智造(客观)", "", -1)
  149. }
  150. perssionName = strings.TrimRight(perssionName, ",")
  151. mapContractIdPerssion[k] = perssionName
  152. }
  153. mapContractResp = make(map[int]string, 0)
  154. //过滤多余的","
  155. for k, v := range mapContractIdPerssion {
  156. sliceName := strings.Split(v, ",")
  157. var nameArr []string
  158. for _, vName := range sliceName {
  159. if vName == "" {
  160. continue
  161. }
  162. if mapIsUpgrade[fmt.Sprint(k, "perssionName", vName)] {
  163. vName += "(升级)"
  164. }
  165. nameArr = append(nameArr, vName)
  166. }
  167. mapContractResp[k] = strings.Join(nameArr, ",")
  168. }
  169. return
  170. }
  171. // GetCompanyPermissionNameStatusMapByCompanyId 通过公司ID,获取公司当下所有权限的状态信息
  172. func GetCompanyPermissionNameStatusMapByCompanyId(companyIds []int) (mapResp map[string]string, err error) {
  173. //return
  174. lenArr := len(companyIds)
  175. if lenArr == 0 {
  176. return
  177. }
  178. var condition string
  179. var pars []interface{}
  180. condition += " AND company_id IN (" + utils.GetOrmInReplace(lenArr) + ") AND product_id = 2 "
  181. pars = append(pars, companyIds)
  182. //获取所有开通买方研选正式试用的客户列表
  183. listCompanyPermission, e := company.GetCompanyReportPermissionList(condition, pars, 0, 0)
  184. if e != nil && e.Error() != utils.ErrNoRow() {
  185. err = errors.New("GetCompanyReportPermissionList, Err: " + e.Error())
  186. return
  187. }
  188. //获取行业权限ID与名称的映射关系
  189. permissionList, e := models.GetChartPermissionList()
  190. if e != nil && e.Error() != utils.ErrNoRow() {
  191. err = errors.New("GetChartPermissionList, Err: " + e.Error())
  192. return
  193. }
  194. mapResp = make(map[string]string, 0)
  195. mapChartPermission := make(map[int]string)
  196. for _, v := range permissionList {
  197. mapChartPermission[v.ChartPermissionId] = v.PermissionName
  198. }
  199. for _, v := range listCompanyPermission {
  200. if mapChartPermission[v.ChartPermissionId] == "" {
  201. continue
  202. }
  203. //公司ID与权限名称组成映射关系
  204. mapResp[fmt.Sprint(v.CompanyId, mapChartPermission[v.ChartPermissionId])] = v.Status
  205. }
  206. return
  207. }
  208. // 判断合同审核通过时间是否超过九十天
  209. func GetMapIsGrayByCompanyContractIds(companyContractIds []int) (mapResp map[int]bool, err error) {
  210. lenArr := len(companyContractIds)
  211. if lenArr == 0 {
  212. return
  213. }
  214. var condition string
  215. var pars []interface{}
  216. pars = make([]interface{}, 0)
  217. condition = " AND company_contract_id IN (" + utils.GetOrmInReplace(lenArr) + ") GROUP BY company_contract_id ORDER BY create_time DESC "
  218. pars = append(pars, companyContractIds)
  219. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  220. if e != nil && e.Error() != utils.ErrNoRow() {
  221. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  222. return
  223. }
  224. //超过九十天就置灰
  225. timeInit := time.Now().AddDate(0, 0, -180)
  226. mapResp = make(map[int]bool, 0)
  227. for _, v := range companyContractPermissionList {
  228. if v.CreateTime.Before(timeInit) {
  229. mapResp[v.CompanyContractId] = true
  230. }
  231. }
  232. return
  233. }
  234. //func init3() {
  235. // var condition string
  236. // var pars []interface{}
  237. // //默认只查询权益 2023-06-01 之后的合同
  238. // condition += ` AND c.product_id = ? AND a.start_date > ? `
  239. // pars = append(pars, 2, "2023-06-01")
  240. //
  241. // //列表页数据
  242. // list, err := cygx.GetCompanyContractListJoinCompany(condition, pars, 0, 1000)
  243. // if err != nil {
  244. // fmt.Println(err)
  245. // return
  246. // }
  247. //
  248. // for _, v := range list {
  249. // fmt.Println(v.CompanyContractId)
  250. // HandleAllocationCompanyContractByYanXuan(v.CompanyContractId)
  251. // }
  252. //
  253. // fmt.Println(len(list))
  254. //}
  255. // 如果合同只有研选的时候,自动处理派点
  256. func HandleAllocationCompanyContractByYanXuan(companyContractId int) (err error) {
  257. defer func() {
  258. if err != nil {
  259. fmt.Println(err)
  260. go alarm_msg.SendAlarmMsg(fmt.Sprint("如果合同只有研选的时候,自动处理派点失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
  261. }
  262. }()
  263. var condition string
  264. var pars []interface{}
  265. pars = make([]interface{}, 0)
  266. condition = " AND company_contract_id = ? "
  267. pars = append(pars, companyContractId)
  268. companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  269. if e != nil && e.Error() != utils.ErrNoRow() {
  270. err = errors.New("GetCompanyContractPermissionList, Err: " + e.Error())
  271. return
  272. }
  273. if e != nil && e.Error() != utils.ErrNoRow() {
  274. err = errors.New("GetCygxAllocationCompanyContractPermissionListById, Err: " + e.Error())
  275. return
  276. }
  277. if len(companyContractPermissionList) > 1 {
  278. return
  279. }
  280. var expensiveYxmoney float64
  281. for _, v := range companyContractPermissionList {
  282. if v.ChartPermissionId != utils.CHART_PERMISSION_ID_YANXUAN {
  283. err = errors.New("没有发现研选权限: ")
  284. return
  285. }
  286. if v.ExpensiveYx == 1 {
  287. expensiveYxmoney = 5
  288. } else if v.ExpensiveYx == 2 {
  289. expensiveYxmoney = 10
  290. } else {
  291. expensiveYxmoney = 3
  292. }
  293. }
  294. var items []*cygx.CygxAllocationCompanyContract
  295. var itemsPermission []*cygx.CygxAllocationCompanyContractPermission
  296. itemPermission := new(cygx.CygxAllocationCompanyContractPermission)
  297. itemPermission.CompanyContractId = companyContractId
  298. //itemPermission.AdminId = sysUser.AdminId
  299. //itemPermission.AdminName = sysUser.RealName
  300. itemPermission.Proportion = 0
  301. itemPermission.Money = expensiveYxmoney
  302. itemPermission.MoneyAvg = 0
  303. itemPermission.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  304. itemPermission.CreateTime = time.Now()
  305. itemPermission.ModifyTime = time.Now()
  306. itemsPermission = append(itemsPermission, itemPermission)
  307. item := new(cygx.CygxAllocationCompanyContract)
  308. item.CompanyContractId = companyContractId
  309. //item.AdminId = sysUser.AdminId
  310. //item.AdminName = sysUser.RealName
  311. item.Proportion = 0
  312. item.Money = expensiveYxmoney
  313. item.RealName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  314. item.ChartPermissionName = utils.CHART_PERMISSION_NAME_MF_YANXUAN
  315. item.CreateTime = time.Now()
  316. item.ModifyTime = time.Now()
  317. items = append(items, item)
  318. e = cygx.AddAndUpdateCygxAllocationCompanyContract(items, itemsPermission, companyContractId)
  319. if e != nil {
  320. err = errors.New("AddAndUpdateCygxAllocationCompanyContract, Err: " + e.Error())
  321. return
  322. }
  323. return
  324. }
  325. //func init() {
  326. // var condition string
  327. // var pars []interface{}
  328. //
  329. // condition = " AND status = 1 "
  330. //
  331. // list, err := company.GetCompanyContractList(condition, pars)
  332. // if err != nil {
  333. // fmt.Println(err)
  334. // return
  335. // }
  336. // fmt.Println(len(list))
  337. // //return
  338. // for _, v := range list {
  339. // fmt.Println(v.CompanyContractId)
  340. // HandleCompanyContractPackageDifference(v.CompanyContractId)
  341. // }
  342. //
  343. //}
  344. // HandleCompanyContractPackageDifference 更新与上一份合同的金额的对比 '增加套餐','减少套餐','维持套餐'
  345. func HandleCompanyContractPackageDifference(companyContractId int) (err error) {
  346. defer func() {
  347. if err != nil {
  348. fmt.Println(err)
  349. go alarm_msg.SendAlarmMsg(fmt.Sprint("更新与上一份合同的金额的对比 '增加套餐','减少套餐','维持套餐'失败,Err:", err.Error(), "companyContractId", companyContractId), 2)
  350. }
  351. }()
  352. var condition string
  353. var pars []interface{}
  354. condition = " AND company_contract_id = ? "
  355. pars = append(pars, companyContractId)
  356. detail, e := company.GetCompanyContracDetail(condition, pars)
  357. if e != nil {
  358. err = errors.New("GetCompanyContracDetail,detail Err: " + e.Error())
  359. return
  360. }
  361. //如果不是续约合同就不做对比处理
  362. if detail.ContractType != "续约合同" {
  363. return
  364. }
  365. //获取前一份合同的信息
  366. pars = make([]interface{}, 0)
  367. condition = " AND company_id = ? AND company_contract_id < ? AND status = 1 AND product_id = ? ORDER BY company_contract_id DESC LIMIT 1 "
  368. pars = append(pars, detail.CompanyId, companyContractId, detail.ProductId)
  369. detailPrevious, e := company.GetCompanyContracDetail(condition, pars)
  370. if e != nil {
  371. err = errors.New("GetCompanyContracDetail,detailPrevious Err: " + e.Error())
  372. return
  373. }
  374. var packageDifference string
  375. if detail.Money > detailPrevious.Money {
  376. packageDifference = "增加套餐"
  377. } else if detail.Money < detailPrevious.Money {
  378. packageDifference = "减少套餐"
  379. } else {
  380. packageDifference = "维持套餐"
  381. }
  382. e = company.UpdateCompanyContractPackageDifference(packageDifference, companyContractId)
  383. if e != nil {
  384. err = errors.New("UpdateCompanyContractPackageDifference, Err: " + e.Error())
  385. return
  386. }
  387. return
  388. }
  389. // HandleCompanyContractPermissionContractType 更新合同权限表中的权限名称,以及对应的行业权限类型(行业新签、行业续约)
  390. func HandleCompanyContractPermissionContractType(companyContractId int) (err error) {
  391. defer func() {
  392. if err != nil {
  393. fmt.Println(err)
  394. go alarm_msg.SendAlarmMsg(fmt.Sprint("更新合同权限表中的权限名称,以及对应的行业权限类型(行业新签、行业续约)失败,HandleCompanyContractPermissionContractType Err:", err.Error(), "companyContractId", companyContractId), 2)
  395. }
  396. }()
  397. var condition string
  398. var pars []interface{}
  399. condition = " AND company_contract_id = ? "
  400. pars = append(pars, companyContractId)
  401. detail, e := company.GetCompanyContracDetail(condition, pars)
  402. if e != nil {
  403. err = errors.New("GetCompanyContracDetail,detail Err: " + e.Error())
  404. return
  405. }
  406. //获取权限ID与名称的map映射
  407. permissionList, e := models.GetChartPermissionList()
  408. if e != nil && e.Error() != utils.ErrNoRow() {
  409. err = errors.New("GetChartPermissionList Err: " + e.Error())
  410. return
  411. }
  412. mapChartPermission := make(map[int]string)
  413. for _, v := range permissionList {
  414. mapChartPermission[v.ChartPermissionId] = v.PermissionName
  415. }
  416. companyId := detail.CompanyId
  417. //如果不是续约合同就不做对比处理
  418. pars = make([]interface{}, 0)
  419. condition = " AND company_contract_id != ? AND company_id = ? "
  420. pars = append(pars, companyContractId, companyId)
  421. //获取历史签约信息
  422. companyContractPermissionListHistory, e := company.GetCompanyContractPermissionList(condition, pars)
  423. if e != nil && e.Error() != utils.ErrNoRow() {
  424. err = errors.New("companyContractPermissionListHistory Err: " + e.Error())
  425. return
  426. }
  427. var mapHistoryPerssionName []string
  428. for _, v := range companyContractPermissionListHistory {
  429. mapHistoryPerssionName = append(mapHistoryPerssionName, mapChartPermission[v.ChartPermissionId])
  430. }
  431. pars = make([]interface{}, 0)
  432. condition = " AND company_contract_id = ? "
  433. pars = append(pars, companyContractId)
  434. //获取当前签约的合同信息
  435. companyContractPermissionLisThis, e := company.GetCompanyContractPermissionList(condition, pars)
  436. if e != nil && e.Error() != utils.ErrNoRow() {
  437. err = errors.New("companyContractPermissionLisThis Err: " + e.Error())
  438. return
  439. }
  440. var items []*company.CompanyContractPermission
  441. for _, v := range companyContractPermissionLisThis {
  442. v.PermissionName = mapChartPermission[v.ChartPermissionId]
  443. if v.PermissionName == "" {
  444. continue
  445. }
  446. //已经存在的属于行业续约、不存在的属于行业新签
  447. if utils.InArrayByStr(mapHistoryPerssionName, v.PermissionName) {
  448. v.ContractType = "行业续约"
  449. } else {
  450. v.ContractType = "行业新签"
  451. }
  452. items = append(items, v)
  453. }
  454. //批量更新合同权限表的权限行业名称,以及签约合同时,当前行业类型(行业续约、行业新签)
  455. e = company.UpdateCompanyContractPermissionMulti(items)
  456. if e != nil {
  457. err = errors.New("UpdateCompanyContractPermissionMulti Err: " + e.Error())
  458. return
  459. }
  460. return
  461. }
  462. func initCRM14_4() {
  463. //func init() {
  464. permissionList, e := models.GetChartPermissionList()
  465. if e != nil && e.Error() != utils.ErrNoRow() {
  466. fmt.Println(permissionList)
  467. return
  468. }
  469. mapChartPermission := make(map[int]string)
  470. for _, v := range permissionList {
  471. mapChartPermission[v.ChartPermissionId] = v.PermissionName
  472. }
  473. var condition string
  474. var pars []interface{}
  475. condition = " AND status = 1 AND product_id = 2 "
  476. companyContractList, e := company.GetCompanyContractList(condition, pars)
  477. if e != nil && e.Error() != utils.ErrNoRow() {
  478. fmt.Println(e)
  479. return
  480. }
  481. fmt.Println(len(companyContractList))
  482. for k, v := range companyContractList {
  483. fmt.Println(k)
  484. HandleCompanyContractPermissionContractType(v.CompanyContractId)
  485. }
  486. //var companyContractIds []int
  487. //for _, v := range companyContractList {
  488. // companyContractIds = append(companyContractIds, v.CompanyContractId)
  489. //}
  490. //condition = " AND company_contract_id IN (" + utils.GetOrmInReplace(len(companyContractIds)) + ") "
  491. //pars = append(pars, companyContractIds)
  492. //
  493. //companyContractPermissionList, e := company.GetCompanyContractPermissionList(condition, pars)
  494. //if e != nil && e.Error() != utils.ErrNoRow() {
  495. // fmt.Println(e)
  496. // return
  497. //}
  498. //
  499. //var items []*company.CompanyContractPermission
  500. //
  501. //for _, v := range companyContractPermissionList {
  502. // v.PermissionName = mapChartPermission[v.ChartPermissionId]
  503. //
  504. // items = append(items, v)
  505. //}
  506. //fmt.Println(len(items))
  507. ////return
  508. //e = company.UpdateCompanyContractPermissionMulti(items)
  509. //if e != nil && e.Error() != utils.ErrNoRow() {
  510. // fmt.Println(e)
  511. // return
  512. //}
  513. }