96SEO 2026-02-20 07:42 0
前言一、遇到的问题二、实现过程1.数据库设计2.实体类3.医生添加排班或修改排班方法4.患者预约方法5.患者修改预约6.患者取消预约

3、如果多为患者同时预约需要使用redis做支撑解决并发问题。
字段名字段类型长度注释guidance_time_idint11排班IDdatedate日期starttimetime开始时间点endtimetime结束时间点numint2可预约次数residueint2剩余可预约次数doctor_idint11医生ID
字段名字段类型长度注释reservation_idint11预约关系IDguidance_time_idint11排班IDpatient_idint11患者IDremarkstext病情描述file_idvarchar256附件IDreservation_typeint11预约类型IDdoctor_idint11医生IDreplytext回复reply_files_idvarchar256回复附件IDstatusint1状态IDisfinishint1是否已完成咨询finish_timedatetime完成咨询的时间create_timedatetime创建时间
医生可预约时间id*/IdGeneratedValue(strategy
GenerationType.IDENTITY)ApiModelProperty(value
剩余可预约次数*/ApiModelProperty(value
预约关系id*/IdGeneratedValue(strategy
GenerationType.IDENTITY)ApiModelProperty(value
是否已完成咨询1是0否*/ApiModelProperty(value
完成咨询的时间*/ApiModelProperty(value
addOrUpdateList(ListRqriGuidanceTime
SimpleDateFormat(HH:mm);SimpleDateFormat
SimpleDateFormat(yyyy-MM-dd);ArrayListString
{collect.add(simpleDateFormat.format(rqriGuidanceTime.getDate()));}ListString
collect.stream().distinct().collect(Collectors.toList());ListRqriGuidanceTime
rqriGuidanceTimeMapper.selectByDateList(list_date);//
(simpleDateFormat.format(rqriGuidanceTimes.get(j).getDate()).equals(item))
{list_update.add(rqriGuidanceTimes.get(j));}}//
(simpleDateFormat.format(rqriGuidanceTime.getDate()).equals(item)
rqriGuidanceTime.getGuidanceTimeId()
(rqriGuidanceTime.getGuidanceTimeId().equals(list_update.get(k).getGuidanceTimeId()))
(!Objects.equals(list_update.get(k).getNum(),
list_update.get(k).getResidue()))
simpleDateFormat1.format(rqriGuidanceTime.getStarttime());String
simpleDateFormat1.format(rqriGuidanceTime.getEndtime());throw
rqriGuidanceTime);}}}}}hashMap_update.put(item,
(simpleDateFormat.format(rqriGuidanceTime.getDate()).equals(value)
rqriGuidanceTime.getGuidanceTimeId()
{list_add.add(rqriGuidanceTime);}}hashMap_add.put(value,
已有的排班与修改的排班ListRqriGuidanceTime
sdf.format(guidanceTime.getStarttime());String
sdf.format(guidanceTime.getEndtime());int
Integer.parseInt(starttime.replace(:,
Integer.parseInt(endtime.replace(:,
sdf.format(rqriGuidanceTime.getStarttime());String
sdf.format(rqriGuidanceTime.getEndtime());int
Integer.parseInt(starttime.replace(:,
Integer.parseInt(endtime.replace(:,
0);}}}}ArrayListRqriGuidanceTime
{list_update.addAll(update);}for
{rqriGuidanceTime.setResidue(rqriGuidanceTime.getNum());rqriGuidanceTimeMapper.updateByPrimaryKey(rqriGuidanceTime);//插入到redisresidueAddRedis(rqriGuidanceTime.getDate(),
rqriGuidanceTime.getGuidanceTimeId().toString(),
rqriGuidanceTime.getResidue());}ArrayListRqriGuidanceTime
{rqriGuidanceTime.setResidue(rqriGuidanceTime.getNum());}if
{rqriGuidanceTimeMapper.insertList(list_add);for
{//插入到redisresidueAddRedis(guidanceTime.getDate(),
guidanceTime.getGuidanceTimeId().toString(),
guidanceTime.getResidue());}}}private
SimpleDateFormat(yyyy-MM-dd);//
dateFormat.format(date).split(-);int
duration.getSeconds();//初始化到redisredisUtils.set(RESERVATION
reservationService.makeReservation(rqriGuidanceTimeRelation.getGuidanceTimeId());if
BusinessException(该时段已无预约次数);}RqriGuidanceTime
rqriGuidanceTimelMapper.selectByPrimaryKey(rqriGuidanceTimeRelation.getGuidanceTimeId());Integer
rqriGuidanceTime.getResidue();//
可预约次数减1rqriGuidanceTime.setResidue(residue
1);rqriGuidanceTimelMapper.updateByPrimaryKey(rqriGuidanceTime);Integer
rqriGuidanceTime.getGuidanceTimeId();redisUtils.decr(RESERVATION
添加预约信息rqriGuidanceTimeRelation.setIsfinish(0);rqriGuidanceTimeRelation.setCreateTime(new
Date());rqriGuidanceTimeRelationMapper.insertSelective(rqriGuidanceTimeRelation);}public
redissonClient.getLock(RESERVATION_LOCK);try
redisTemplate.opsForValue().decrement(key);if
预约已满预约失败需要将可预约数量还原redisTemplate.opsForValue().increment(key);return
reservationService.makeReservation(guidanceTimeId);if
Exception(该时段已无预约次数);}//查询新的时段是RqriGuidanceTime
rqriGuidanceTimelMapper.selectByPrimaryKey(guidanceTimeId);
查询原预约时段idRqriGuidanceTimeRelation
rqriGuidanceTimeRelationMapper.selectByPrimaryKey(reservationId);//根据原预约时段id获取原预约时段数据RqriGuidanceTime
rqriGuidanceTimelMapper.selectByPrimaryKey(rqriGuidanceTimeRelation.getGuidanceTimeId());//原预约时段次数
1);old.setResidue(old.getResidue()
1);//更新原时段rqriGuidanceTimelMapper.updateByPrimaryKey(old);//新预约时段剩余次数-1newGuidanceTime.setResidue(newGuidanceTime.getResidue()
1);rqriGuidanceTimelMapper.updateByPrimaryKey(newGuidanceTime);//更新预约详情rqriGuidanceTimeRelation.setGuidanceTimeId(guidanceTimeId);rqriGuidanceTimeRelationMapper.updateByPrimaryKey(rqriGuidanceTimeRelation);}
delete(RqriGuidanceTimeRelation
rqriGuidanceTimelMapper.selectByPrimaryKey(rqriGuidanceTimeRelation.getGuidanceTimeId());rqriGuidanceTime.setResidue(rqriGuidanceTime.getResidue()
1);rqriGuidanceTimelMapper.updateByPrimaryKey(rqriGuidanceTime);rqriGuidanceTimeRelationMapper.delete(rqriGuidanceTimeRelation);redisUtils.incr(RESERVATION
rqriGuidanceTimeRelation.getGuidanceTimeId(),
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback