用户自定义排序的几种实现思路

场景

每个用户,有多个分组
每个分组在页面展示,而且是有顺序的,这个顺序是由用户决定

以下是关于多种情况下的库表设计思路:

情景一:如果每改一次,就要实时修改库,而且用户可以任意修改顺序,比如5个分组,由54321改为51432

方案1:

用户表,用一个字段存分组表的顺序,比如(1分组Id,2分组Id,3分组Id)
分组表
每次用户修改顺序,只改用户表的这个字段。
查询的时候查出该用户所有分组,按照这个字段排序输出到前端。

方案2:分组表,每个分组加一个权重字段

每次用户修改顺序,对应修改所有分组的这个权重字段(有事务)
查询按照这个权重字段排序即可

方案3:链表思想,每个分组都有一个值,还存有上一个值和下一个值,比如5个分组12345

那么1分组存值1,上一个值null,下一个值2
那么2分组存值2,上一个值1,下一个值3
那么3分组存值3,上一个值2,下一个值4
那么4分组存值4,上一个值3,下一个值5
那么5分组存值5,上一个值4,下一个值null

这时如果要把顺序12345改成14325,只需要
1分组存值1,上一个值null,下一个值2
那么4分组存值4,上一个权重值1,下一个值3
那么3分组存值3,上一个值4,下一个值2
那么2分组存值4,上一个值3,下一个值5
那么5分组存值5,上一个值4,下一个值null

情景一总结:

方案1,要借助用户表来存储分组顺序,而这个属于业务字段,存在用户表中不合适
方案2,有事务,必须多个分组的修改同时成功
方案3,多了3个字段,而且和链表一样,增删改快,查询慢。适合部分小的场景

情景二:如果每改一次,就要实时修改库,但用户只能上下修改,具体参考支付宝设置中的支付顺序的修改

方案4:比如有5个组权重值分别为12345

由于每个分组每次修改只能和相邻的分组互换权重值,所以这个比较好实现
每次都做一个事务的修改,事务中就只有相邻的两个分组交换权重值。

情景三:如果专门有个页面,供用户修改,最终保存,这种最好实现,也最low,用户体验不好,具体可参考讯飞输入法常用语的分组设置模式

方案5:每次前台改完,都有新的顺序,比如初5个组的初始权重是A-1,B-2,C-3,D-4,E-5

改后可能完全乱了,比如改后可能是A-2,B-3,C-1,D-5,E-4.
那么这种就只能在一个事务中分别修改5个分组的权重了。

总结

以上方案,如果非要改进,还可以加一层缓存,尤其是情景一,当然,任何大一点的项目,数据库前面都最好有缓存挡着。
而且针对情景一和情景二,还可以考虑用阻塞队列的思路,考虑到用户多次修改后,总会停下来,比如设置3秒,3秒内取队列的最后一个修改的顺序,
这时候相当于用阻塞队列将情景一和情景二强行转换成情景三的实现方式,而且用户体验还比单纯的情景三要好

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/499918.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

重构,体现一个工程师的基本素养和底蕴

重构小记(重构,改善既有代码的设计读后总结) 我们要时时刻刻保持一颗项目要重构的心。 在非技术出身的领导看来,能用的代码就是好代码,只关注功能。 在工程师看来,代码不仅要好用,更要好看&…

应用内购买(IAP)各类型在服务端的验证规则

一、非消耗品(比如单本杂志购买,苹果服务器支持恢复) 1.先验证服务器有没有购买记录,如果有,则不处理,此次操作成功 ;2.如果服务器没有购买记录,则到苹果服务器验证(1)首先到正式验证地址验证收据,如果返回…

@Transactional事务生效条件与样例

Transactional事务生效条件 Transactional注释的方法,不能是private修饰 Transactional注释的方法,必须是有接口的方法实现(通用的Spring面向接口编程的套路) Transactional注释的方法,必须要通过接口的方式调用&…

利用.dSYM和.app文件准确定位Crash位置

当发布到iPhone上的应用程序Crash之后,iPhone会自动生成一个Crash Log(*.crash),这个文件包含了一些有用的调试信息,但对于堆栈,它只记录的函数地址,而无法显示函数名。函数名保存在一个叫dSYM的…

使用maven的profile区分本地环境和线上环境

使用maven的profile区分本地环境和线上环境 多环境开发,使用maven-profile,就可以在打包的时候通过参数的调整,最终打的包也不同。 以区分本地数据库和线上数据库为例 比如测试环境,用的是本地测试数据库;生产环境用…

查看函数库.a函数符号信息

一、概述 nm命令可以列出一个函数库文件中的符号表。它对于静态的函数库和共享的函数库都起作用。对于一个给定的函数库,nm命令可以列出函数库中定义的所有符号,包括每个符号的值和类型。还可以给出在原程序中这个函数(符号)是在多…

重构,体现一个工程师的基本素养和底蕴(细节篇)

重构小记(重构,改善既有代码的设计读后总结) 方法级别 提炼函数: 将一个大方法,拆成多个小方法,难点在于小方法的命名。 假如有早上上学的一个大方法, 那么就应该在里面有起床,穿衣…

MVPVM模式介绍

一、概述MVPVM即:Model-View-Presenter-ViewModel。此模式是MVVM和MVP模式的结合体。但是交互模式发生了比较大的变化。MVVM参考本博客文章:iOS-MVVM-模式介绍MVP参考本博客文章:MVP模式介绍 二、原理:Presenter同时持有View、Mod…

[线程池] ------ 形象的描述线程池,用一个特好记的例子来记忆

线程池 为了减少线程频繁的创建和销毁过程,引入池的概念。 将一些线程先创建好放在线程池中,每次来任务就用池中的线程执行,空闲时池中线程就等待,但不销毁。 原始线程池的创建: ThreadPoolExecutor executor1 new …

分组密码的工作模式

一、理论基础1.概述密码学中,块密码的工作模式允许使用同一个块密码密钥对多于一块的数据进行加密,并保证其安全性。块密码自身只能加密长度等于密码块长度的单块数据,若要加密变长数据,则数据必须先被划分为一些单独的密码块。通…

数据仓库基本认知

数据仓库概念: 数据仓库,英文名称Data Warehouse,简写为DW。 是一种面向分析的存储系统。 他是一个很大的数据存储集合,出于企业的分析性报告和决策支持目的而创建,对多样的业务数据进行筛选与整合。 它为企业提供一…

PBOC3.0中使用的国密SM2算法

一、知识准备 PBOC3.0规范就是《中国金融集成电路(IC)卡规范》3.0版本。SM2是国密局推出的一种他们自己说具有自主知识产权的非对称商用密码算法。本身是基于ECC椭圆曲线算法的,所以要讲SM2, 先要弄懂ECC。 完全理解ECC算法需要一定的数学功底…

mapper注入失败,NoSuchBeanDefinitionException: No qualifying bean of type [com.xxx.XxxMapper] found for d

mapper注入失败: Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.xxx.XxxMapper] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependen…

战地体能训练模拟器

一、名称:战地体能训练模拟器二、整体介绍: 1.体验者身处一个封闭空间的正中央,空间内部表面全部附着显示器,包含地板(因为地板是平的,可以使用投影的方式实现),经过视角上的设计,体验者就像身处…

java读文件写文件

使用了try-with-resource语法(JDK1.7及以上),代码更加便捷 Junit测试样例,先写入文件,再读出来: RunWith(SpringJUnit4ClassRunner.class) ContextConfiguration(locations "classpath:spring-conf…

Markdown入门

Markdown 是一种轻量级的「标记语言」,它的优点很多,目前也被越来越多的写作爱好者,撰稿者广泛使用。看到这里请不要被「标记」、「语言」所迷惑,Markdown 的语法十分简单。常用的标记符号也不超过十个,这种相对于更为…

bean注入失败的几种情况和解决思路:NoSuchBeanDefinitionException: No qualifying bean of type

bean注入失败,无非是两种情况,要么注入的写法出错,要么被注入的Bean未定义。 1.Bean未定义 如果是直接在XML中配置bean标签的时候 检查id和class是否写对 如果是用注解形式申明Bean 先检查Controller、Service、Repository、 Component …

通过AVFoundation框架获取摄像头数据

一、概述 从iOS4开始,AVFoundation框架增加了几个类,AVCaptureDevice、AVCaptureSession等,可以获取摄像头的数据,而不会弹出类似于ImagePicker一样的界面,我们可以将数据转为一张张的图片,然后我们可以即时…

mysql数据库支持emoji表情的详解

mysql存储emoji表情的时候,就会报错,如下: Error updating database. Cause: java.sql.SQLException: Incorrect string value: ‘\xF0\x9F\x98\x8A\xF0\x9F…’ for column ‘这是我表中的字段’ at row 1 初步定位是我的数据库是utf8编码…

CoreText使用介绍

一、概述 1.CoreText是苹果创建的一个用于文字排版的框架,可以实现文字排版、图文混排等复杂的界面效果。从iOS3.2启用。2.一个开源工具类-OHAttributedLabel,就是使用CoreText框架实现的,能够实现一个Label中有不同的文字大小、文字颜色、字…