Bläddra i källkod

Merge branch 'master' of http://git.ycjcjy.com/zhiyuxing/estateagents

张延森 5 år sedan
förälder
incheckning
7b05a0f713
20 ändrade filer med 372 tillägg och 18 borttagningar
  1. 52
    4
      src/main/java/com/huiju/estateagents/controller/StatisticalController.java
  2. 1
    4
      src/main/java/com/huiju/estateagents/controller/TaPersonIntentionRecordController.java
  3. 2
    2
      src/main/java/com/huiju/estateagents/controller/TaSaveController.java
  4. 12
    0
      src/main/java/com/huiju/estateagents/entity/TaPersonIntentionRecord.java
  5. 8
    0
      src/main/java/com/huiju/estateagents/mapper/TaBuildingDynamicMapper.java
  6. 8
    0
      src/main/java/com/huiju/estateagents/mapper/TaBuildingMapper.java
  7. 9
    0
      src/main/java/com/huiju/estateagents/mapper/TaNewsMapper.java
  8. 4
    0
      src/main/java/com/huiju/estateagents/mapper/TaPersonIntentionRecordMapper.java
  9. 15
    4
      src/main/java/com/huiju/estateagents/mapper/TaPersonMapper.java
  10. 18
    1
      src/main/java/com/huiju/estateagents/mapper/TaPersonVisitRecordMapper.java
  11. 33
    0
      src/main/java/com/huiju/estateagents/service/IStatisticalService.java
  12. 4
    0
      src/main/java/com/huiju/estateagents/service/ITaPersonIntentionRecordService.java
  13. 69
    1
      src/main/java/com/huiju/estateagents/service/impl/StatisticalServiceImpl.java
  14. 13
    0
      src/main/java/com/huiju/estateagents/service/impl/TaPersonIntentionRecordServiceImpl.java
  15. 12
    0
      src/main/resources/mapper/TaBuildingDynamicMapper.xml
  16. 12
    0
      src/main/resources/mapper/TaBuildingMapper.xml
  17. 13
    0
      src/main/resources/mapper/TaNewsMapper.xml
  18. 11
    0
      src/main/resources/mapper/TaPersonIntentionRecordMapper.xml
  19. 65
    2
      src/main/resources/mapper/TaPersonMapper.xml
  20. 11
    0
      src/main/resources/mapper/TaPersonVisitRecordMapper.xml

+ 52
- 4
src/main/java/com/huiju/estateagents/controller/StatisticalController.java Visa fil

@@ -3,10 +3,9 @@ package com.huiju.estateagents.controller;
3 3
 import com.huiju.estateagents.base.ResponseBean;
4 4
 import com.huiju.estateagents.service.IStatisticalService;
5 5
 import org.springframework.beans.factory.annotation.Autowired;
6
-import org.springframework.web.bind.annotation.GetMapping;
7
-import org.springframework.web.bind.annotation.RequestMapping;
8
-import org.springframework.web.bind.annotation.RequestMethod;
9
-import org.springframework.web.bind.annotation.RestController;
6
+import org.springframework.web.bind.annotation.*;
7
+
8
+import java.util.Date;
10 9
 
11 10
 /**
12 11
  * 数据统计
@@ -27,5 +26,54 @@ public class StatisticalController {
27 26
         return iStatisticalService.indexStatistical();
28 27
     }
29 28
 
29
+    /**
30
+     * 活跃用户数
31
+     * @return
32
+     */
33
+    @GetMapping(value = "/selectActiveUserCount")
34
+    public ResponseBean selectActiveUserCount(@RequestParam String dateType) {
35
+        return iStatisticalService.selectActiveUserCount(dateType);
36
+    }
37
+
38
+    /**
39
+     * 活跃用户数
40
+     * @return
41
+     */
42
+    @GetMapping(value = "/selectNewsUserCount")
43
+    public ResponseBean selectNewsUserCount(@RequestParam(required = false) Date startDate,
44
+                                            @RequestParam(required = false) Date endDate) {
45
+        return iStatisticalService.selectNewsUserCount(startDate, endDate);
46
+    }
47
+
48
+    /**
49
+     * 用户行为
50
+     * @return
51
+     */
52
+    @GetMapping(value = "/selectUserBehavior")
53
+    public ResponseBean selectUserBehavior(@RequestParam(required = false) Date startDate,
54
+                                            @RequestParam(required = false) Date endDate) {
55
+        return iStatisticalService.selectUserBehavior(startDate, endDate);
56
+    }
57
+
58
+
59
+    /**
60
+     * 行为分析的 列表
61
+     * @return
62
+     */
63
+    @GetMapping(value = "/selectUserBehaviorAll")
64
+    public ResponseBean selectUserBehaviorAll(@RequestParam(required = false) Integer pageNum,
65
+                                           @RequestParam(required = false) Integer pageCode) {
66
+        return iStatisticalService.selectUserBehaviorAll(pageNum, pageCode);
67
+    }
68
+
69
+    /**
70
+     * 行为分析的 具体数据列表
71
+     * @return
72
+     */
73
+    @GetMapping(value = "/selectEventAll")
74
+    public ResponseBean selectEventAll(@RequestParam(required = false) String event,
75
+                                              @RequestParam(required = false) Integer personId) {
76
+        return iStatisticalService.selectEventAll(event, personId);
77
+    }
30 78
 
31 79
 }

+ 1
- 4
src/main/java/com/huiju/estateagents/controller/TaPersonIntentionRecordController.java Visa fil

@@ -49,11 +49,8 @@ public class TaPersonIntentionRecordController extends BaseController {
49 49
         try {
50 50
             //使用分页插件
51 51
 		    IPage<TaPersonIntentionRecord> pg = new Page<>(pageNum, pageSize);
52
-            QueryWrapper<TaPersonIntentionRecord> queryWrapper = new QueryWrapper<>();
53
-            queryWrapper.orderByDesc("create_date");
54 52
 
55
-            IPage<TaPersonIntentionRecord> result = iTaPersonIntentionRecordService.page(pg, queryWrapper);
56
-            responseBean.addSuccess(result);
53
+            responseBean = iTaPersonIntentionRecordService.selectAll(pg);
57 54
         }catch (Exception e){
58 55
             logger.error("taPersonIntentionRecordList -=- {}",e.toString());
59 56
             responseBean.addError(e.getMessage());

+ 2
- 2
src/main/java/com/huiju/estateagents/controller/TaSaveController.java Visa fil

@@ -26,7 +26,7 @@ public class TaSaveController extends BaseController {
26 26
     private ITaSaveService iTaSaveService;
27 27
 
28 28
     /**
29
-     * 点赞
29
+     * 收藏
30 30
      * @param typeOf
31 31
      * @param id
32 32
      * @param request
@@ -40,7 +40,7 @@ public class TaSaveController extends BaseController {
40 40
     }
41 41
 
42 42
     /**
43
-     * 取消
43
+     * 取消收藏
44 44
      * @param typeOf
45 45
      * @param id
46 46
      * @param request

+ 12
- 0
src/main/java/com/huiju/estateagents/entity/TaPersonIntentionRecord.java Visa fil

@@ -1,6 +1,7 @@
1 1
 package com.huiju.estateagents.entity;
2 2
 
3 3
 import com.baomidou.mybatisplus.annotation.IdType;
4
+import com.baomidou.mybatisplus.annotation.TableField;
4 5
 import com.baomidou.mybatisplus.annotation.TableId;
5 6
 import java.time.LocalDateTime;
6 7
 import java.io.Serializable;
@@ -84,5 +85,16 @@ public class TaPersonIntentionRecord implements Serializable {
84 85
      */
85 86
     private Integer orgId;
86 87
 
88
+    /**
89
+     * 手机号
90
+     */
91
+    @TableField(exist = false)
92
+    private String phone;
93
+
94
+    /**
95
+     * 意向值总和
96
+     */
97
+    @TableField(exist = false)
98
+    private Integer intentionCount;
87 99
 
88 100
 }

+ 8
- 0
src/main/java/com/huiju/estateagents/mapper/TaBuildingDynamicMapper.java Visa fil

@@ -8,6 +8,8 @@ import org.apache.ibatis.annotations.Mapper;
8 8
 import org.apache.ibatis.annotations.Param;
9 9
 import org.apache.ibatis.annotations.Update;
10 10
 
11
+import java.util.Map;
12
+
11 13
 /**
12 14
  * <p>
13 15
  * 项目动态表 Mapper 接口
@@ -55,4 +57,10 @@ public interface TaBuildingDynamicMapper extends BaseMapper<TaBuildingDynamic> {
55 57
     void setFieldNum(@Param("newsId") String newsId, @Param("field") String field, @Param("increment") int increment);
56 58
 
57 59
     void updateTaBuildingDynamic(@Param("dynamicId") String dynamicId, @Param("sum") String sum);
60
+
61
+    /**
62
+     * 转化率 活动收藏 / 活动分享
63
+     * @return
64
+     */
65
+    Map<String, Object> selectBuildingDynamicStatistical(String saveOrShare);
58 66
 }

+ 8
- 0
src/main/java/com/huiju/estateagents/mapper/TaBuildingMapper.java Visa fil

@@ -6,9 +6,11 @@ import com.huiju.estateagents.entity.TaBuilding;
6 6
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
7 7
 import org.apache.ibatis.annotations.Mapper;
8 8
 import org.apache.ibatis.annotations.Param;
9
+import org.apache.ibatis.annotations.Select;
9 10
 import org.apache.ibatis.annotations.Update;
10 11
 
11 12
 import java.util.List;
13
+import java.util.Map;
12 14
 
13 15
 /**
14 16
  * <p>
@@ -38,4 +40,10 @@ public interface TaBuildingMapper extends BaseMapper<TaBuilding> {
38 40
      * @return
39 41
      */
40 42
     TaBuilding selectBuilding(@Param("buildingId") String buildingId);
43
+
44
+    /**
45
+     * 转化率 项目收藏 / 项目分享
46
+     * @return
47
+     */
48
+    Map<String, Object> selectBuildingStatistical(String saveOrShare);
41 49
 }

+ 9
- 0
src/main/java/com/huiju/estateagents/mapper/TaNewsMapper.java Visa fil

@@ -6,6 +6,8 @@ import org.apache.ibatis.annotations.Mapper;
6 6
 import org.apache.ibatis.annotations.Param;
7 7
 import org.apache.ibatis.annotations.Update;
8 8
 
9
+import java.util.Map;
10
+
9 11
 /**
10 12
  * <p>
11 13
  * 资讯表  Mapper 接口
@@ -26,4 +28,11 @@ public interface TaNewsMapper extends BaseMapper<TaNews> {
26 28
     @Update("UPDATE ta_news  SET ${field} = IFNULL(${field}, 0) + #{increment}  WHERE news_id = #{newsId}")
27 29
     void setFieldNum(@Param("newsId") String newsId, @Param("field") String field, @Param("increment") int increment);
28 30
 
31
+
32
+    /**
33
+     * 转化率 咨迅收藏 / 咨迅分享
34
+     * @return
35
+     */
36
+    Map<String, Object> selectNewsStatistical(String saveOrShare);
37
+
29 38
 }

+ 4
- 0
src/main/java/com/huiju/estateagents/mapper/TaPersonIntentionRecordMapper.java Visa fil

@@ -2,6 +2,7 @@ package com.huiju.estateagents.mapper;
2 2
 
3 3
 
4 4
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
5
+import com.baomidou.mybatisplus.core.metadata.IPage;
5 6
 import com.huiju.estateagents.entity.TaPersonIntentionRecord;
6 7
 import org.apache.ibatis.annotations.Mapper;
7 8
 
@@ -16,4 +17,7 @@ import org.apache.ibatis.annotations.Mapper;
16 17
 @Mapper
17 18
 public interface TaPersonIntentionRecordMapper extends BaseMapper<TaPersonIntentionRecord> {
18 19
 
20
+
21
+    IPage<TaPersonIntentionRecord> selectAll(IPage<TaPersonIntentionRecord> page);
22
+
19 23
 }

+ 15
- 4
src/main/java/com/huiju/estateagents/mapper/TaPersonMapper.java Visa fil

@@ -92,6 +92,14 @@ public interface TaPersonMapper extends BaseMapper<TaPerson> {
92 92
      */
93 93
     List<Map<String, Object>> selectActiveUserCount(@Param("personType") String personType, @Param("dateType") String dateType, @Param("startDate")Date startDate, @Param("endDate")Date endDate);
94 94
 
95
+    /**
96
+     * 新增用户数
97
+     * @param personType
98
+     * @param startDate
99
+     * @param endDate
100
+     * @return
101
+     */
102
+    List<Map<String, Object>> selectNewsUserCount(@Param("personType") String personType, @Param("startDate")Date startDate, @Param("endDate")Date endDate);
95 103
 
96 104
     /**
97 105
      * 性别比例
@@ -102,10 +110,13 @@ public interface TaPersonMapper extends BaseMapper<TaPerson> {
102 110
     List<Map<String, Object>> selectSexUser(@Param("personType") String personType);
103 111
 
104 112
 
105
-
106
-
107
-
108
-
113
+    /**
114
+     * 城市比例
115
+     * @param personType
116
+     * @return
117
+     */
118
+    @Select("select city, count(1) from ta_person where person_type = #{personType} GROUP BY city")
119
+    List<Map<String, Object>> selectCityUser(@Param("personType") String personType);
109 120
 
110 121
 
111 122
 }

+ 18
- 1
src/main/java/com/huiju/estateagents/mapper/TaPersonVisitRecordMapper.java Visa fil

@@ -7,6 +7,7 @@ import com.huiju.estateagents.entity.TaPerson;
7 7
 import com.huiju.estateagents.entity.TaPersonVisitRecord;
8 8
 import org.apache.ibatis.annotations.Mapper;
9 9
 import org.apache.ibatis.annotations.Param;
10
+import org.apache.ibatis.annotations.Select;
10 11
 
11 12
 import java.util.List;
12 13
 
@@ -20,7 +21,23 @@ import java.util.List;
20 21
  */
21 22
 @Mapper
22 23
 public interface TaPersonVisitRecordMapper extends BaseMapper<TaPersonVisitRecord> {
23
-    List<TaPersonVisitRecord>visitRecordByPersonId(@Param("personId") String personId);
24 24
 
25
+    List<TaPersonVisitRecord> visitRecordByPersonId(@Param("personId") String personId);
26
+
27
+    /**
28
+     * 行为分析的 列表
29
+     * @param page
30
+     * @return
31
+     */
32
+    IPage<TaPersonVisitRecord> selectAll(IPage<TaPersonVisitRecord> page);
33
+
34
+
35
+    /**
36
+     * 行为分析的 具体数据
37
+     *
38
+     * @return
39
+     */
40
+    @Select("select * from ta_person_visit_record where event = #{event} and person_id = #{personId}")
41
+    List<TaPersonVisitRecord> selectEventAll(@Param("event") String event, @Param("personId") Integer personId);
25 42
 
26 43
 }

+ 33
- 0
src/main/java/com/huiju/estateagents/service/IStatisticalService.java Visa fil

@@ -2,6 +2,8 @@ package com.huiju.estateagents.service;
2 2
 
3 3
 import com.huiju.estateagents.base.ResponseBean;
4 4
 
5
+import java.util.Date;
6
+
5 7
 /**
6 8
  * 数据统计 接口
7 9
  */
@@ -19,4 +21,35 @@ public interface IStatisticalService {
19 21
      */
20 22
     ResponseBean selectActiveUserCount(String dateType);
21 23
 
24
+    /**
25
+     * 新增用户数
26
+     * @param startDate
27
+     * @param endDate
28
+     * @return
29
+     */
30
+    ResponseBean selectNewsUserCount(Date startDate,Date endDate);
31
+
32
+    /**
33
+     * 用户行为
34
+     * @param startDate
35
+     * @param endDate
36
+     * @return
37
+     */
38
+    ResponseBean selectUserBehavior(Date startDate,Date endDate);
39
+
40
+    /**
41
+     * 行为分析的 列表
42
+     * @param pageNum
43
+     * @param pageCode
44
+     * @return
45
+     */
46
+    ResponseBean selectUserBehaviorAll(Integer pageNum, Integer pageCode);
47
+
48
+    /**
49
+     * 行为分析的 具体数据列表
50
+     * @param event
51
+     * @param personId
52
+     * @return
53
+     */
54
+    ResponseBean selectEventAll(String event, Integer personId);
22 55
 }

+ 4
- 0
src/main/java/com/huiju/estateagents/service/ITaPersonIntentionRecordService.java Visa fil

@@ -1,7 +1,9 @@
1 1
 package com.huiju.estateagents.service;
2 2
 
3 3
 
4
+import com.baomidou.mybatisplus.core.metadata.IPage;
4 5
 import com.baomidou.mybatisplus.extension.service.IService;
6
+import com.huiju.estateagents.base.ResponseBean;
5 7
 import com.huiju.estateagents.entity.TaPersonIntentionRecord;
6 8
 
7 9
 /**
@@ -14,4 +16,6 @@ import com.huiju.estateagents.entity.TaPersonIntentionRecord;
14 16
  */
15 17
 public interface ITaPersonIntentionRecordService extends IService<TaPersonIntentionRecord> {
16 18
 
19
+
20
+    ResponseBean selectAll(IPage<TaPersonIntentionRecord> pg);
17 21
 }

+ 69
- 1
src/main/java/com/huiju/estateagents/service/impl/StatisticalServiceImpl.java Visa fil

@@ -1,9 +1,14 @@
1 1
 package com.huiju.estateagents.service.impl;
2 2
 
3
+import com.baomidou.mybatisplus.core.metadata.IPage;
4
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
3 5
 import com.huiju.estateagents.base.ResponseBean;
4 6
 import com.huiju.estateagents.common.CommConstant;
7
+import com.huiju.estateagents.entity.TaPersonVisitRecord;
5 8
 import com.huiju.estateagents.exception.EstaException;
9
+import com.huiju.estateagents.mapper.TaBuildingMapper;
6 10
 import com.huiju.estateagents.mapper.TaPersonMapper;
11
+import com.huiju.estateagents.mapper.TaPersonVisitRecordMapper;
7 12
 import com.huiju.estateagents.po.PersonPO;
8 13
 import com.huiju.estateagents.service.IStatisticalService;
9 14
 import lombok.extern.slf4j.Slf4j;
@@ -11,6 +16,7 @@ import org.springframework.beans.factory.annotation.Autowired;
11 16
 import org.springframework.stereotype.Service;
12 17
 
13 18
 import java.time.LocalDateTime;
19
+import java.util.Date;
14 20
 import java.util.HashMap;
15 21
 import java.util.List;
16 22
 import java.util.Map;
@@ -25,6 +31,12 @@ public class StatisticalServiceImpl implements IStatisticalService {
25 31
     @Autowired
26 32
     private TaPersonMapper taPersonMapper;
27 33
 
34
+    @Autowired
35
+    private TaBuildingMapper taBuildingMapper;
36
+
37
+
38
+    @Autowired
39
+    private TaPersonVisitRecordMapper taPersonVisitRecordMapper;
28 40
 
29 41
     @Override
30 42
     public ResponseBean indexStatistical() {
@@ -44,18 +56,30 @@ public class StatisticalServiceImpl implements IStatisticalService {
44 56
         // 用户行为
45 57
         List<PersonPO> selectUserBehavior = taPersonMapper.selectUserBehavior(CommConstant.PERSON_REALTY_CONSULTANT, null, null);
46 58
 
47
-        // 用户活跃数 / 新增用户数
59
+        // 用户活跃数
48 60
         List<Map<String, Object>> selectActiveUserCount = taPersonMapper.selectActiveUserCount(CommConstant.PERSON_REALTY_CONSULTANT, CommConstant.DAY, null, null);
49 61
 
62
+        // 新增用户数
63
+        List<Map<String, Object>> selectNewsUserCount = taPersonMapper.selectNewsUserCount(CommConstant.PERSON_REALTY_CONSULTANT, null, null);
64
+
50 65
         // 性别比例
51 66
         List<Map<String, Object>> selectSexUser = taPersonMapper.selectSexUser(CommConstant.PERSON_REALTY_CONSULTANT);
52 67
 
68
+        // 城市比例
69
+        List<Map<String, Object>> selectCityUser = taPersonMapper.selectCityUser(CommConstant.PERSON_REALTY_CONSULTANT);
70
+
71
+        // 转化率, 当前 默认项目收藏
72
+        Map<String, Object> selectBuildingStatistical = taBuildingMapper.selectBuildingStatistical("save");
73
+
53 74
         map.put("selectUserCount", selectUserCount);
54 75
         map.put("selectRegisteredCount", selectRegisteredCount);
55 76
         map.put("selectRecentlyCount", selectRecentlyCount);
56 77
         map.put("selectUserBehavior", selectUserBehavior);
57 78
         map.put("selectActiveUserCount", selectActiveUserCount);
79
+        map.put("selectNewsUserCount", selectNewsUserCount);
58 80
         map.put("selectSexUser", selectSexUser);
81
+        map.put("selectCityUser", selectCityUser);
82
+        map.put("selectBuildingStatistical", selectBuildingStatistical);
59 83
 
60 84
         responseBean.addSuccess(map);
61 85
 
@@ -84,4 +108,48 @@ public class StatisticalServiceImpl implements IStatisticalService {
84 108
         responseBean.addSuccess(map);
85 109
         return responseBean;
86 110
     }
111
+
112
+    @Override
113
+    public ResponseBean selectNewsUserCount(Date startDate, Date endDate) {
114
+        ResponseBean responseBean = new ResponseBean();
115
+
116
+        // 新增用户数
117
+        List<Map<String, Object>> selectNewsUserCount = taPersonMapper.selectNewsUserCount(CommConstant.PERSON_REALTY_CONSULTANT, startDate, endDate);
118
+
119
+        Map<String, Object> map = new HashMap<>();
120
+        map.put("selectNewsUserCount", selectNewsUserCount);
121
+        responseBean.addSuccess(map);
122
+        return responseBean;
123
+    }
124
+
125
+    @Override
126
+    public ResponseBean selectUserBehavior(Date startDate, Date endDate) {
127
+        ResponseBean responseBean = new ResponseBean();
128
+
129
+        // 用户行为
130
+        List<PersonPO> selectUserBehavior = taPersonMapper.selectUserBehavior(CommConstant.PERSON_REALTY_CONSULTANT, startDate, endDate);
131
+
132
+        Map<String, Object> map = new HashMap<>();
133
+        map.put("selectUserBehavior", selectUserBehavior);
134
+        responseBean.addSuccess(map);
135
+        return responseBean;
136
+    }
137
+
138
+    @Override
139
+    public ResponseBean selectUserBehaviorAll(Integer pageNum, Integer pageSize) {
140
+        ResponseBean responseBean = new ResponseBean();
141
+        IPage<TaPersonVisitRecord> page = new Page<>(pageNum, pageSize);
142
+        IPage<TaPersonVisitRecord> visitRecordIPage = taPersonVisitRecordMapper.selectAll(page);
143
+        responseBean.addSuccess(visitRecordIPage);
144
+        return responseBean;
145
+    }
146
+
147
+    @Override
148
+    public ResponseBean selectEventAll(String event, Integer personId) {
149
+        ResponseBean responseBean = new ResponseBean();
150
+
151
+        List<TaPersonVisitRecord> taPersonVisitRecords = taPersonVisitRecordMapper.selectEventAll(event, personId);
152
+        responseBean.addSuccess(taPersonVisitRecords);
153
+        return responseBean;
154
+    }
87 155
 }

+ 13
- 0
src/main/java/com/huiju/estateagents/service/impl/TaPersonIntentionRecordServiceImpl.java Visa fil

@@ -1,10 +1,13 @@
1 1
 package com.huiju.estateagents.service.impl;
2 2
 
3 3
 
4
+import com.baomidou.mybatisplus.core.metadata.IPage;
4 5
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
6
+import com.huiju.estateagents.base.ResponseBean;
5 7
 import com.huiju.estateagents.entity.TaPersonIntentionRecord;
6 8
 import com.huiju.estateagents.mapper.TaPersonIntentionRecordMapper;
7 9
 import com.huiju.estateagents.service.ITaPersonIntentionRecordService;
10
+import org.springframework.beans.factory.annotation.Autowired;
8 11
 import org.springframework.stereotype.Service;
9 12
 
10 13
 /**
@@ -18,4 +21,14 @@ import org.springframework.stereotype.Service;
18 21
 @Service
19 22
 public class TaPersonIntentionRecordServiceImpl extends ServiceImpl<TaPersonIntentionRecordMapper, TaPersonIntentionRecord> implements ITaPersonIntentionRecordService {
20 23
 
24
+    @Autowired
25
+    private TaPersonIntentionRecordMapper taPersonIntentionRecordMapper;
26
+
27
+    @Override
28
+    public ResponseBean selectAll(IPage<TaPersonIntentionRecord> pg) {
29
+        ResponseBean responseBean = new ResponseBean();
30
+        IPage<TaPersonIntentionRecord> taPersonIntentionRecordIPage = taPersonIntentionRecordMapper.selectAll(pg);
31
+        responseBean.addSuccess(taPersonIntentionRecordIPage);
32
+        return responseBean;
33
+    }
21 34
 }

+ 12
- 0
src/main/resources/mapper/TaBuildingDynamicMapper.xml Visa fil

@@ -86,4 +86,16 @@
86 86
 	      dynamic_id = #{dynamicId}
87 87
     </select>
88 88
 
89
+    <select id="selectBuildingDynamicStatistical" resultType="map">
90
+            select
91
+            sum(pv_num) as pvNum,
92
+            <if test="saveOrShare === 'save'">
93
+                sum(save_num) as saveNum
94
+            </if>
95
+            <if test="saveOrShare === 'share'">
96
+                sum(share_num) as shareNum
97
+            </if>
98
+            from ta_building_dynamic
99
+    </select>
100
+
89 101
 </mapper>

+ 12
- 0
src/main/resources/mapper/TaBuildingMapper.xml Visa fil

@@ -25,4 +25,16 @@
25 25
          where building_id = #{buildingId}
26 26
     </select>
27 27
 
28
+    <select id="selectBuildingStatistical" resultType="map">
29
+        select
30
+          sum(pv_num) as pvNum,
31
+          <if test="saveOrShare === 'save'">
32
+              sum(save_num) as saveNum
33
+          </if>
34
+          <if test="saveOrShare === 'share'">
35
+              sum(share_num) as shareNum
36
+          </if>
37
+        from ta_building
38
+    </select>
39
+
28 40
 </mapper>

+ 13
- 0
src/main/resources/mapper/TaNewsMapper.xml Visa fil

@@ -2,4 +2,17 @@
2 2
 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
3 3
 <mapper namespace="com.huiju.estateagents.mapper.TaNewsMapper">
4 4
 
5
+
6
+    <select id="selectNewsStatistical" resultType="map" >
7
+        select
8
+        sum(pv_num) as pvNum,
9
+        <if test="saveOrShare === 'save'">
10
+            sum(save_num) as saveNum
11
+        </if>
12
+        <if test="saveOrShare === 'share'">
13
+            sum(share_num) as shareNum
14
+        </if>
15
+        from ta_news
16
+    </select>
17
+
5 18
 </mapper>

+ 11
- 0
src/main/resources/mapper/TaPersonIntentionRecordMapper.xml Visa fil

@@ -2,4 +2,15 @@
2 2
 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
3 3
 <mapper namespace="com.huiju.estateagents.mapper.TaPersonIntentionRecordMapper">
4 4
 
5
+    <select id="selectAll" resultType="com.huiju.estateagents.entity.TaPersonIntentionRecord">
6
+        SELECT
7
+            *,
8
+            tp.phone as phone,
9
+            SUM(tpir.intention) as intentionCount
10
+        FROM
11
+            ta_person_intention_record tpir
12
+            LEFT JOIN ta_person tp ON tpir.person_id = tp.person_id
13
+            GROUP BY tpir.person_id
14
+    </select>
15
+
5 16
 </mapper>

+ 65
- 2
src/main/resources/mapper/TaPersonMapper.xml Visa fil

@@ -195,7 +195,7 @@ FROM
195 195
             INNER JOIN ta_person_visit_record tpvr ON tp.person_id = tpvr.person_id
196 196
             where tp.person_type = #{personType}
197 197
             GROUP BY tpvr.activity
198
-        ) AS temp ON temp_date.date = DATE_FORMAT( temp.visit_time , '%Y-%m-%d' )
198
+        ) AS temp ON temp_date.date = DATE_FORMAT( temp.visitTime , '%Y-%m-%d' )
199 199
     </select>
200 200
 
201 201
     <select id="selectActiveUserCount" resultType="map">
@@ -229,9 +229,72 @@ FROM
229 229
                 tpvr.visit_time AS visit_time
230 230
             FROM
231 231
                ta_person tp
232
-            where tp.person_type = #{personType}
233 232
             INNER JOIN ta_person_visit_record tpvr ON tp.person_id = tpvr.person_id
233
+             where tp.person_type = #{personType}
234 234
         ) AS temp ON temp_date.date = DATE_FORMAT( temp.visit_time , '%Y-%m-%d' )
235 235
     </select>
236 236
 
237
+    <select id="selectNewsUserCount" >
238
+        SELECT
239
+        consultant_count_table.date as date,
240
+        consultant_count_table.consultant_count as consultant_count,
241
+        user_count_table.user_count as user_count
242
+        FROM
243
+        (
244
+            SELECT
245
+              *
246
+            FROM
247
+            (
248
+                SELECT
249
+                DATE_FORMAT( DATE_SUB( now( ), INTERVAL a.rownum DAY ), '%Y-%m-%d' ) AS date
250
+                FROM
251
+                sequence a
252
+                WHERE
253
+                <if test="startDate == null or endDate == null">
254
+                    a.rownum <![CDATA[ <= ]]> 7
255
+                </if>
256
+                <if test="startDate != null or endDate != null">
257
+                    a.rownum <![CDATA[ <= ]]> datediff(#{endDate}, #{startDate})
258
+                </if>
259
+            ) AS temp_date
260
+            LEFT JOIN (
261
+                SELECT
262
+                COUNT(1) as consultant_count,
263
+                tpvr.visit_time AS visit_time
264
+                FROM
265
+                ta_person tp
266
+                INNER JOIN ta_person_visit_record tpvr ON tp.person_id = tpvr.person_id
267
+                where tp.person_type = 'Realty Consultant'
268
+            ) AS temp ON temp_date.date = DATE_FORMAT( temp.visit_time , '%Y-%m-%d' )
269
+        ) as consultant_count_table
270
+        ,
271
+        (SELECT
272
+        *
273
+        FROM
274
+        (
275
+            SELECT
276
+            DATE_FORMAT( DATE_SUB( now( ), INTERVAL a.rownum DAY ), '%Y-%m-%d' ) AS date
277
+            FROM
278
+            sequence a
279
+            WHERE
280
+            <if test="startDate == null or endDate == null">
281
+                a.rownum <![CDATA[ <= ]]> 7
282
+            </if>
283
+            <if test="startDate != null or endDate != null">
284
+                a.rownum <![CDATA[ <= ]]> datediff(#{endDate}, #{startDate})
285
+            </if>
286
+        ) AS temp_date
287
+        LEFT JOIN (
288
+            SELECT
289
+            COUNT(1) as user_count,
290
+            tpvr.visit_time AS visit_time
291
+            FROM
292
+            ta_person tp
293
+            INNER JOIN ta_person_visit_record tpvr ON tp.person_id = tpvr.person_id
294
+        ) AS temp ON temp_date.date = DATE_FORMAT( temp.visit_time , '%Y-%m-%d' )
295
+
296
+        ) as user_count_table
297
+        GROUP BY date
298
+    </select>
299
+
237 300
 </mapper>

+ 11
- 0
src/main/resources/mapper/TaPersonVisitRecordMapper.xml Visa fil

@@ -6,4 +6,15 @@
6 6
         where person_id = #{personId}
7 7
     </select>
8 8
 
9
+    <select id="selectAll">
10
+        SELECT
11
+            tpvr.*,
12
+            tp.name,
13
+            COUNT(1) as accessCount
14
+        FROM
15
+            ta_person_visit_record tpvr
16
+            LEFT JOIN ta_person tp ON tpvr.person_id = tp.person_id
17
+        GROUP BY tpvr.person_id, tpvr.event
18
+    </select>
19
+
9 20
 </mapper>