company_user.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  1. package tables
  2. import (
  3. "fmt"
  4. "hongze/hongze_open_api/utils"
  5. "rdluck_tools/orm"
  6. )
  7. type ViewReportList struct {
  8. CompanyName string `description:"公司名称" json:"company_name"`
  9. RealName string `description:"用户名称" json:"user_name"`
  10. Mobile string `description:"手机号" json:"mobile"`
  11. Email string `description:"邮箱" json:"email"`
  12. ResearchReportName string `description:"报告标题" json:"report_name"`
  13. CreatedTime string `description:"报告阅读时间" json:"created_time"`
  14. ReportType string `description:"报告类型 'day 晨报'、'week 周报'、'twoweek 双周报'、'month 月报'、'rddp 日度点评'、'cygx 查研观向'、'advisory 每日商品聚焦'" json:"-"`
  15. TxtType string `description:"类型 ficc:ficc 、 rights:权益" json:"-"`
  16. MatchTypeName string `description:"匹配类型" json:"-"`
  17. StopTime string `description:"停留时间" json:"-"`
  18. }
  19. type ViewReportListResp struct {
  20. Total int `description:"数量"`
  21. List []*ViewReportList
  22. }
  23. func GetViewReportListByMobile(mobile string, txtType int) (items []*ViewReportList, err error) {
  24. dataName := ""
  25. sql := ``
  26. if utils.RunMode == "debug" {
  27. dataName = "test_v2_hongze_rddp"
  28. } else {
  29. dataName = "hongze_rddp"
  30. }
  31. ficcSql := `SELECT
  32. rr.research_report_name,
  33. rr.type AS report_type,
  34. 'ficc' AS txt_type,
  35. '--' AS match_type_name,
  36. '--' AS stop_time,
  37. uvh.created_time AS created_time
  38. FROM
  39. user_view_history uvh
  40. LEFT JOIN research_report rr ON rr.research_report_id = uvh.research_report_id
  41. WHERE
  42. uvh.mobile = ?
  43. UNION ALL
  44. SELECT
  45. r.title AS research_report_name,
  46. 'rddp' AS report_type,
  47. 'ficc' AS txt_type,
  48. r.classify_name_first AS match_type_name,
  49. '--' AS stop_time,
  50. rvr.create_time AS created_time
  51. FROM %s.report_view_record rvr
  52. LEFT JOIN %s.report r ON r.id = rvr.report_id
  53. WHERE
  54. rvr.mobile=?
  55. UNION ALL
  56. SELECT
  57. cha.permission_name AS research_report_name,
  58. 'advisory' AS report_type,
  59. 'ficc' AS txt_type,
  60. cha.classify_name AS match_type_name,
  61. '--' AS stop_time,
  62. auc.create_time AS created_time
  63. FROM
  64. advisory_user_chart_article_record auc
  65. LEFT JOIN chart_permission cha ON cha.chart_permission_id = auc.chart_permission_id
  66. WHERE
  67. auc.mobile = ?`
  68. rightsSql := `SELECT
  69. art.title AS research_report_name,
  70. 'cygx' AS report_type,
  71. 'rights' AS txt_type,
  72. art.match_type_name,
  73. h.stop_time,
  74. h.create_time AS created_time
  75. FROM
  76. cygx_article_history_record h
  77. LEFT JOIN cygx_article art ON art.article_id = h.article_id
  78. WHERE
  79. h.mobile = ? `
  80. if txtType == 1 {
  81. sql = ` SELECT * FROM ( ` + rightsSql + `
  82. )AS t ORDER BY t.created_time DESC`
  83. } else if txtType == 2 {
  84. sql = ` SELECT * FROM ( ` + ficcSql + `
  85. )AS t ORDER BY t.created_time DESC`
  86. } else {
  87. sql = ` SELECT * FROM ( ` + ficcSql + " UNION ALL " + rightsSql + `
  88. )AS t ORDER BY t.created_time DESC`
  89. }
  90. //报告统计删除晨报部分统计加入每日资讯 2021-4-9
  91. //sql := ` SELECT * FROM (
  92. // SELECT
  93. // r.title AS research_report_name,
  94. // 'rddp' AS report_type,
  95. // rvr.create_time AS created_time
  96. // FROM %s.report_view_record rvr
  97. // INNER JOIN %s.report r ON r.id = rvr.report_id
  98. // WHERE
  99. // rvr.mobile=?
  100. // UNION ALL
  101. // SELECT
  102. // cha.permission_name AS research_report_name,
  103. // 'advisory' AS report_type,
  104. // auc.create_time AS created_time
  105. // FROM
  106. // advisory_user_chart_article_record auc
  107. // INNER JOIN chart_permission cha ON cha.chart_permission_id = auc.chart_permission_id
  108. // WHERE
  109. // auc.mobile = ?
  110. // )AS t ORDER BY t.created_time DESC
  111. // `
  112. o := orm.NewOrm()
  113. if txtType == 1 {
  114. _, err = o.Raw(sql, mobile).QueryRows(&items)
  115. } else if txtType == 2 {
  116. sql = fmt.Sprintf(sql, dataName, dataName)
  117. _, err = o.Raw(sql, mobile, mobile, mobile).QueryRows(&items)
  118. } else {
  119. sql = fmt.Sprintf(sql, dataName, dataName)
  120. _, err = o.Raw(sql, mobile, mobile, mobile, mobile).QueryRows(&items)
  121. }
  122. return
  123. }
  124. func GetViewReportListByEmail2(email string, txtType int) (items []*ViewReportList, err error) {
  125. dataName := ""
  126. sql := ``
  127. if utils.RunMode == "debug" {
  128. dataName = "test_hongze_rddp"
  129. } else {
  130. dataName = "hongze_rddp"
  131. }
  132. ficcSql := `SELECT
  133. rr.research_report_name,
  134. rr.type AS report_type,
  135. 'ficc' AS txt_type,
  136. '--' AS match_type_name,
  137. '--' AS stop_time,
  138. uvh.created_time AS created_time
  139. FROM
  140. user_view_history uvh
  141. INNER JOIN research_report rr ON rr.research_report_id = uvh.research_report_id
  142. WHERE
  143. uvh.email = ?
  144. UNION ALL
  145. SELECT
  146. r.title AS research_report_name,
  147. 'rddp' AS report_type,
  148. 'ficc' AS txt_type,
  149. r.classify_name_first AS match_type_name,
  150. '--' AS stop_time,
  151. rvr.create_time AS created_time
  152. FROM %s.report_view_record rvr
  153. INNER JOIN %s.report r ON r.id = rvr.report_id
  154. WHERE
  155. rvr.email=?
  156. UNION ALL
  157. SELECT
  158. cha.permission_name AS research_report_name,
  159. 'advisory' AS report_type,
  160. 'ficc' AS txt_type,
  161. cha.classify_name AS match_type_name,
  162. '--' AS stop_time,
  163. auc.create_time AS created_time
  164. FROM
  165. advisory_user_chart_article_record auc
  166. INNER JOIN chart_permission cha ON cha.chart_permission_id = auc.chart_permission_id
  167. WHERE
  168. auc.email = ?`
  169. rightsSql := `SELECT
  170. art.title AS research_report_name,
  171. 'cygx' AS report_type,
  172. 'rights' AS txt_type,
  173. art.match_type_name,
  174. h.stop_time,
  175. h.create_time AS created_time
  176. FROM
  177. cygx_article_history_record h
  178. INNER JOIN cygx_article art ON art.article_id = h.article_id
  179. WHERE
  180. h.email = ? `
  181. if txtType == 1 {
  182. sql = ` SELECT * FROM ( ` + rightsSql + `
  183. )AS t ORDER BY t.created_time DESC`
  184. } else if txtType == 2 {
  185. sql = ` SELECT * FROM ( ` + ficcSql + `
  186. )AS t ORDER BY t.created_time DESC`
  187. } else {
  188. sql = ` SELECT * FROM ( ` + ficcSql + " UNION ALL " + rightsSql + `
  189. )AS t ORDER BY t.created_time DESC`
  190. }
  191. //报告统计删除晨报部分统计加入每日资讯 2021-4-9
  192. //sql := ` SELECT * FROM (
  193. // SELECT
  194. // r.title AS research_report_name,
  195. // 'rddp' AS report_type,
  196. // rvr.create_time AS created_time
  197. // FROM %s.report_view_record rvr
  198. // INNER JOIN %s.report r ON r.id = rvr.report_id
  199. // WHERE
  200. // rvr.mobile=?
  201. // UNION ALL
  202. // SELECT
  203. // cha.permission_name AS research_report_name,
  204. // 'advisory' AS report_type,
  205. // auc.create_time AS created_time
  206. // FROM
  207. // advisory_user_chart_article_record auc
  208. // INNER JOIN chart_permission cha ON cha.chart_permission_id = auc.chart_permission_id
  209. // WHERE
  210. // auc.mobile = ?
  211. // )AS t ORDER BY t.created_time DESC
  212. // `
  213. o := orm.NewOrm()
  214. if txtType == 1 {
  215. _, err = o.Raw(sql, email).QueryRows(&items)
  216. } else if txtType == 2 {
  217. sql = fmt.Sprintf(sql, dataName, dataName)
  218. _, err = o.Raw(sql, email, email, email).QueryRows(&items)
  219. } else {
  220. sql = fmt.Sprintf(sql, dataName, dataName)
  221. _, err = o.Raw(sql, email, email, email, email).QueryRows(&items)
  222. }
  223. return
  224. }
  225. // GetViewReportCount 获取报告列表
  226. func GetViewReportList(mobile,email,startDate,endDate string, startSize, pageSize int) (total int,items []*ViewReportList, err error) {
  227. dataName := ""
  228. sql := ``
  229. var sql1,sql2,sql3 string
  230. var pars []interface{}
  231. if mobile != "" && email !=""{
  232. sql1 = ` and ( uvh.mobile = ? or uvh.email = ? ) `
  233. sql2 = ` and ( rvr.mobile = ? or rvr.email = ? `
  234. sql3 = ` and ( auc.mobile = ? or auc.email = ? `
  235. pars = append(pars,mobile,email,mobile,email,mobile,email)
  236. }else if mobile != ""{
  237. sql1 = ` and ( uvh.mobile = ? ) `
  238. sql2 = ` and ( rvr.mobile = ? ) `
  239. sql3 = ` and ( auc.mobile = ? ) `
  240. pars = append(pars,mobile,mobile,mobile)
  241. }else if email != ""{
  242. sql1 = ` and ( uvh.email = ? ) `
  243. sql2 = ` and ( rvr.email = ? ) `
  244. sql3 = ` and ( auc.email = ? ) `
  245. pars = append(pars,email,email,email)
  246. }
  247. //时间筛选
  248. if startDate != ""&& endDate !=""{
  249. sql1 = ` and uvh.created_time >= ? and uvh.created_time <= ? `
  250. pars = append(pars,startDate,endDate)
  251. sql2 = ` and rvr.create_time >= ? and rvr.create_time <= ? `
  252. pars = append(pars,startDate,endDate)
  253. sql3 = ` and auc.create_time >= ? and auc.create_time <= ? `
  254. pars = append(pars,startDate,endDate)
  255. }
  256. if utils.RunMode == "debug" {
  257. dataName = "test_v2_hongze_rddp"
  258. } else {
  259. dataName = "hongze_rddp"
  260. }
  261. ficcSql := `SELECT
  262. rr.research_report_name,
  263. rr.type AS report_type,
  264. 'ficc' AS txt_type,
  265. '--' AS match_type_name,
  266. '--' AS stop_time,
  267. uvh.created_time AS created_time,uvh.mobile,uvh.email,uvh.real_name,uvh.company_name
  268. FROM
  269. user_view_history uvh
  270. LEFT JOIN research_report rr ON rr.research_report_id = uvh.research_report_id
  271. WHERE 1=1
  272. `+ sql1 +`
  273. UNION ALL
  274. SELECT
  275. r.title AS research_report_name,
  276. 'rddp' AS report_type,
  277. 'ficc' AS txt_type,
  278. r.classify_name_first AS match_type_name,
  279. '--' AS stop_time,
  280. rvr.create_time AS created_time,rvr.mobile,rvr.email,rvr.real_name,rvr.company_name
  281. FROM %s.report_view_record rvr
  282. LEFT JOIN %s.report r ON r.id = rvr.report_id
  283. WHERE 1=1 `+ sql2 +`
  284. UNION ALL
  285. SELECT
  286. cha.permission_name AS research_report_name,
  287. 'advisory' AS report_type,
  288. 'ficc' AS txt_type,
  289. cha.classify_name AS match_type_name,
  290. '--' AS stop_time,
  291. auc.create_time AS created_time,auc.mobile,auc.email,auc.real_name,auc.company_name
  292. FROM
  293. advisory_user_chart_article_record auc
  294. LEFT JOIN chart_permission cha ON cha.chart_permission_id = auc.chart_permission_id
  295. WHERE 1=1 `+sql3
  296. sql = ` SELECT * FROM ( ` + ficcSql + ` )AS t ORDER BY t.created_time DESC`
  297. o := orm.NewOrm()
  298. sql = fmt.Sprintf(sql, dataName, dataName)
  299. totalSql := `SELECT count(*) total FROM ( ` + sql + ` )AS z `
  300. err = o.Raw(totalSql, pars).QueryRow(&total)
  301. if err != nil{
  302. return
  303. }
  304. sql += ` limit ?,?`
  305. _, err = o.Raw(sql, pars,startSize,pageSize).QueryRows(&items)
  306. return
  307. }
  308. // GetViewReportCount 获取报告列表总数
  309. func GetViewReportCount(mobile,email string) (total int, err error) {
  310. dataName := ""
  311. sql := ``
  312. var sql1,sql2,sql3 string
  313. var pars []interface{}
  314. if mobile != "" && email !=""{
  315. sql1 = `uvh.mobile = ? or uvh.email = ? `
  316. sql2 = `rvr.mobile = ? or rvr.email = ? `
  317. sql3 = `auc.mobile = ? or auc.email = ? `
  318. pars = append(pars,mobile,email,mobile,email,mobile,email)
  319. }else if mobile != ""{
  320. sql1 = `uvh.mobile = ? `
  321. sql2 = `rvr.mobile = ? `
  322. sql3 = `auc.mobile = ? `
  323. pars = append(pars,mobile,mobile,mobile)
  324. }else if email != ""{
  325. sql1 = `uvh.email = ? `
  326. sql2 = `rvr.email = ? `
  327. sql3 = `auc.email = ? `
  328. pars = append(pars,email,email,email)
  329. }
  330. if utils.RunMode == "debug" {
  331. dataName = "test_v2_hongze_rddp"
  332. } else {
  333. dataName = "hongze_rddp"
  334. }
  335. ficcSql := `SELECT
  336. rr.research_report_name,
  337. rr.type AS report_type,
  338. 'ficc' AS txt_type,
  339. '--' AS match_type_name,
  340. '--' AS stop_time,
  341. uvh.created_time AS created_time
  342. FROM
  343. user_view_history uvh
  344. LEFT JOIN research_report rr ON rr.research_report_id = uvh.research_report_id
  345. WHERE
  346. `+ sql1 +`
  347. UNION ALL
  348. SELECT
  349. r.title AS research_report_name,
  350. 'rddp' AS report_type,
  351. 'ficc' AS txt_type,
  352. r.classify_name_first AS match_type_name,
  353. '--' AS stop_time,
  354. rvr.create_time AS created_time
  355. FROM %s.report_view_record rvr
  356. LEFT JOIN %s.report r ON r.id = rvr.report_id
  357. WHERE `+ sql2 +`
  358. UNION ALL
  359. SELECT
  360. cha.permission_name AS research_report_name,
  361. 'advisory' AS report_type,
  362. 'ficc' AS txt_type,
  363. cha.classify_name AS match_type_name,
  364. '--' AS stop_time,
  365. auc.create_time AS created_time
  366. FROM
  367. advisory_user_chart_article_record auc
  368. LEFT JOIN chart_permission cha ON cha.chart_permission_id = auc.chart_permission_id
  369. WHERE `+sql3
  370. sql = ` SELECT count(*) total FROM ( ` + ficcSql + `
  371. )AS t ORDER BY t.created_time DESC`
  372. o := orm.NewOrm()
  373. sql = fmt.Sprintf(sql, dataName, dataName)
  374. err = o.Raw(sql, pars).QueryRow(&total)
  375. return
  376. }