• 小程序项目业务逻辑回忆3


    1.用户激活票劵

    在我的票劵未激活票劵查询业务中,票劵是可以通过激活按钮进行激活的

    该业务涉及3个表users用户信息表\order_items门票订单关联表\signin_records签到信息表

    用户激活票劵时,首先使用该用户user_id创建signin_record表,signin_record表中门票类型ticket_type为"会议",

    signin_record表签到状态sign_in_status为"未签到",registration_number为order_item登记号复制,并且使用登记号去生成二维码保存到signin_recode表二维码code_url(用于已激活票劵UI界面展示,参会时凭借二维码进场)

    通过order_item中的activiation_code票劵代码去查询被激活的那张票(一个订单下的一张票),变更该票即某一字段order_item票劵状态更改为"已激活",默认为未激活,复制登记号,生成激活时间.

    根据UI界面要求(完全可以省略,没必要),用该用户的user_id去更新姓名name\证件类型id_type和证件号id_number

    设计数据库签到记录表signin_records

    通用主键id、用户id user_id,门票类型(展览或会议,这里是会议,会议需花钱购买门票激活,展览登录注册即可免费参展),登记号registration_number,sigin_time门票生成时间,sigin_in_status签到状态,code_url二维码url

    2.查询用户激活票劵

    由于用户只能激活一张会议门票,筛选order_item表中current_owner_id为本人(安全考虑,正常当前拥有者不是本人,在未激活列表中激活功能中是看不见的,但是转赠接收过程中存在时间差,及票劵状态为转赠过程中,以防万一用户激活两张票劵做的一层校验),code_status为激活状态,

    由于只能激活一张票劵,所以在激活功能中需插入查询功能,查询有已激活票劵,需友好提示用户激活票劵只能本人使用及只能激活一张,否则查询功能会报错,MP框架getone方法查询出2个及2个以上结果时会在日志报错,所以激活及激活查询后端自测时需连同一起测试,查看数据库中是否保存错误信息或遗漏字段没有填充

    此时返给前端registration_number登记号,用user_id和ticket_id去user表和ticket表中连表查询用户的姓名和登记号,连同order_items中的code_url一同封装返给前端,

    3.查询用户未激活票劵

    直接查询返回给前端所需数据即可

    可以用到的小技巧

    sql中返回统计数量count(*),需用到group_by,使用any_value(  )  as 返回别名,可简化sql不用group by

    ,

  • 相关阅读:
    HTML 速查列表
    Nginx 修改server_name后无法访问
    Java版本spring cloud + spring boot企业电子招投标系统源代码
    【线性代数】P4 行列式相乘+范德蒙德行列式+克莱姆法则 cramer
    【详细】Java网络通信 TCP、UDP、InetAddress
    数据结构与算法编程题7
    问题:anaconda的bin和envs目录莫名奇妙消失!
    【前端面试题2】
    SpringCloud(十)——ElasticSearch简单了解(二)DSL查询语句及RestClient查询文档
    【LeetCode与《代码随想录》】贪心算法篇:做题笔记与总结-JavaScript版
  • 原文地址:https://blog.csdn.net/sunyunfei1994/article/details/139862271