答案:系统实现用户报名与统计分析,包含活动发布、报名防重、数据存储及可视化功能;采用Spring Boot+MySQL+Vue技术栈,通过唯一索引防止重复报名,MyBatis-Plus操作数据库,ECharts展示统计图表。

开发一个在线活动报名统计系统,核心是实现用户报名、数据收集与统计分析功能。Java作为后端主力语言,结合Spring Boot、MySQL和前端技术,可以快速搭建稳定高效的系统。下面从需求分析到代码实现,一步步解析该项目的实战开发过程。
明确系统功能需求
一个基础的活动报名统计系统应包含以下功能模块:
- 活动发布:管理员可创建活动,设置名称、时间、地点、人数限制等信息
- 用户报名:用户填写姓名、电话、邮箱等信息进行报名
- 报名数据存储:所有报名信息持久化保存到数据库
- 实时统计展示:按活动显示已报名人数、性别分布、来源渠道等统计图表
- 防重复提交:同一用户(手机号或邮箱)不能重复报名同一活动
技术选型与项目结构设计
使用主流Java技术栈构建系统,确保可维护性和扩展性。
- 后端框架:Spring Boot + Spring MVC + MyBatis-Plus
- 数据库:MySQL 存储活动和报名记录
- 接口通信:RESTful API,返回JSON格式数据
- 前端展示:Vue.js 或 Thymeleaf 模板引擎(简单项目可用后者)
- 图表展示:ECharts 或 Chart.js 实现统计可视化
项目包结构建议:
立即学习“Java免费学习笔记(深入)”;
com.example.activitysystem├── controller
├── service
├── mapper
├── entity
├── dto(数据传输对象)
└── config(如数据库配置、跨域配置)
数据库表设计关键点
合理的表结构是系统稳定运行的基础。
- 活动表(activity):id, title, start_time, end_time, location, max_participants, created_by
- 报名表(registration):id, activity_id, name, phone, email, gender, source(如微信、官网), register_time
注意在 registration 表中添加唯一索引:
ALTER TABLE registration ADD UNIQUE INDEX idx_phone_activity (phone, activity_id);这样可防止同一手机号重复报名同一活动。
核心功能代码实现示例
以报名接口为例,展示关键逻辑处理。
实体类 Registration.java ```java public class Registration { private Long id; private Long activityId; private String name; private String phone; private String email; private String gender; private String source; private LocalDateTime registerTime; // getter 和 setter 省略 } ```Service 层判断重复报名
@Service
public class RegistrationService {
@Autowired
private RegistrationMapper registrationMapper;
public boolean isDuplicate(String phone, Long activityId) {
QueryWrapper wrapper = new QueryWrapper<>();
wrapper.eq("phone", phone).eq("activity_id", activity_id);
return registrationMapper.selectCount(wrapper) > 0;
}
public boolean saveRegistration(Registration reg) {
if (isDuplicate(reg.getPhone(), reg.getActivityId())) {
return false;
}
reg.setRegisterTime(LocalDateTime.now());
return registrationMapper.insert(reg) > 0;
}
} Controller 返回统一格式
@RestController
@RequestMapping("/api/registration")
public class RegistrationController {
@Autowired
private RegistrationService registrationService;
@PostMapping
public ResponseEntity register(@RequestBody Registration reg) {
if (registrationService.saveRegistration(reg)) {
return ResponseEntity.ok("报名成功");
} else {
return ResponseEntity.badRequest().body("该手机号已报名,请勿重复提交");
}
}
} 统计功能实现思路
统计接口用于后台展示数据,例如按性别统计:
Mapper 接口 ```java @Select("SELECT gender, COUNT(*) as count FROM registration WHERE activity_id = #{activityId} GROUP BY gender") List










