说明一下这里的操作:
注:
(1)我们可以多次追加、删除之后再点击保存
(2)当前页修改未保存,不能跳转到其他页面
很多地方都涉及到了保存,那么保存的逻辑是什么呢?
例如我下面这个操作流程:
删除第一条
删除第二条
在第3条下追加
删除第四条
在第5条追加
(上面这些操作只是在前端并没有保存到后端)
点击保存按钮(这时发起请求,才会在数据库中显示)
那我传送什么给后端来告知用户对数据做了什么操作呢?
方案一
删除服务 + 追加服务
依次调用删除和追加服务(追加服务中需要有一个参数标识在哪个位置进行了追加,
还有一点需要注意的是之前的删除操作会改变位置)
前端处理起来应该挺有些麻烦,需要计算一些变动的位置
方案二
直接将前端修改过后的所有数据(不区分删除、追加)整个传输给后端,后端先清掉之前的然后
再保存现有
操作简单,但是很多数据可能不需要上传(就算你删除一条数据也需要上传初删除的那一条之外的数据)
同步执行不行吗,就是对删除行操作就同步调用接口处理,在我看来是最简单的处理方式了,是什么原因不愿意进行同步执行
类似功能我做过,大体来就下面这些步骤
前端
row-remove
之类的row-edit
row-edit
或 row-remove
的,归到 edit 和 remove 数组项内, 最终的提交数据类似:{ data : { create:{}, edit:{}, remove:{} } }
后端:
insert
, update
, delete
即可,insert
和 update
要考虑数据唯一性约束 产生冲突 要怎么处理,如不会有就省事很多版本字段
。提交时带上 读取时的 版本号,版本号一致可以更新,否则提示:数据在提交前已被其他人修改
类似的信息嗨,我有一个角色表和一个权限表,它有多对多的关系。我已经创建了下面链接中提到的实体 https://www.baeldung.com/jpa-多对多 角色实体 权限实体 我已经为每个实体创建了JPA存储库,并且正在尝试将权限保存给一个角色。我在表中已经有了一组/列表的权限,我正在尝试将它们映射到某个角色。我正在尝试使用spring JPA存储库执行下面的代码。 在执行我得到的代码时 org.hib
问题内容: 我想一次从JTable删除几行,但一次只能删除一行。JTable一次只能允许一个选择吗?如果我想通过选择删除多行,java是否允许我们这样做?给定的代码一次只能删除一行,即使我选择了多行也是如此。 是连接到MySql数据库的类。 是变量的名称 是通过使用Getter Setter类从MySql导入数据来更新我的行和列的函数 这是我尝试过的代码: 问题答案: 下面显示了如何从JTable
我正在本地机器中将spark数据集保存为拼花文件。我想知道是否有任何方法可以使用某种加密算法对数据进行加密。我用来将数据保存为拼花文件的代码如下所示。 <代码>数据集。写入()。模式(“覆盖”)。拼花地板 我看到了一个类似的问题,但我的查询不同,因为我正在写入本地磁盘。
在发出delete操作之前,我必须在表行上更新这些信息(before delete触发器将负责从表中复制相关数据)。当我尝试从hibernate保存并删除时,hibernate将完全跳过保存。当然...假设如果要删除实体,那么执行保存操作是没有意义的,这是有意义的....但这不是我刚才告诉你的情况。 在执行删除之前提交事务可能会成功,但这意味着需要一个新的事务,加上我正在处理的更多对象必须重新加载
问题内容: 我有一个包含分层数据的表。 列“ ParentId”保存其父级的ID(“ ID”-关键列)。 删除一行时,我要删除所有子级(所有级别的嵌套)。 怎么做? 谢谢 问题答案: 当行数不太大时,erikkallen的递归方法起作用。 这是使用临时表收集所有子项的替代方法: 它从带有@delete_id的行开始,然后从那里开始。where语句用于防止递归;如果您确定没有任何内容,则可以将其忽略
我有一个包含两行的数据表和一个列,其中有一个带有删除该行中对象的简单按钮的表单。 首先是工作版本: 这就是deleteActor方法的样子: 所以这完全按照预期工作。 然而,当我使用如图所示的素数面的分页数据表时,删除按钮仅在第二种情况下的第一行起作用,并且仅在第一次起作用。当我点击其他行的“删除”按钮时,什么也没发生。原因可能是什么? 对于第二种情况,只需将