教您多人填报时如何防止内容覆盖

楼主
我是社区第238588位番薯,欢迎点我头像关注我哦~
经常会有用户反映使用填报功能的时候,多人同时填报可能会出现,后填报的覆盖掉先填报的问题。那么怎么才能实现多人填报互不干扰呢,其实思路很简单,只需要在数据库表中新增一个主键:填报人ID。这样就能将不同人填写的内容分别写成新记录,而不是覆盖掉。这边给大家提供了一个示例,让我们一起来看看怎么实现的。


1. 设计数据库表
数据库表中新增 4 个字段,将填报人和订单ID同时设置为主键。



2. 设计填报表格
填报时只要填 3 个字段就行,填报人字段是为了防止填报覆盖的,这个后面我们会将它设置成自动填入数据库表中的。


3. 设置填报属性
注意这里我们要将填报人字段的值设置为公式:$fine_username,这样提交时会将填报者的用户名填写到数据库填报人这个字段中去。
所以我们需要设置登录才能填报,这样才能用 $fine_username 获取每个人的用户名


4. 填报演示
将这个报表挂载到决策系统中,让用户先登录再填报。

这里用2个用户给大家演示下,分别是用户名为Alice跟Lily的用户。
Alice 先填报:

Lily 后填报:

她们都提交成功后,数据库表信息如下图,我们可以看到,订单ID是数据库表的一个主键,Alice 和 Lily 都填报了相同的订单ID,但是没有出现覆盖。
正是由于用户名作为联合主键,可以让她们生成各自的记录。


5.模板下载
这个模板是连接的我自己的 SQL Server 数据库,所以预览模板时没啥用哈,您可以自己建一个表试试
订单销量表填报.cpt (7.82 KB, 下载次数: 14)






编辑于 2021-6-18 15:47  
分享扩散:

沙发
发表于 2021-6-19 13:29:01
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1回帖数 1关注人数 4642浏览人数
最后回复于:2021-6-19 13:29

返回顶部 返回列表