在开发过程遇到了一个很纠结的问题。
就是我想把新发表的或在整个内容列表任意的位置的内容,移动到内容列表指定的位置!举个例子:
order id
---------------
4 1
3 2
2 3
1 4
我想把ID为4的数据移动到ID为2的下面。我目前的处理办法是目标ID的ORDER+1(-1)的方式来进行排序,但是,像这种有序的列表,就会出现ORDER相同的值,这个时候,在进行排序最终结果有点出乎意料。
有什么办法能够解决这个问题?
回复讨论(解决方案)
order by `order`, id
order 相同的按 id 排序
只要你遵守自己的约定,就不会出现 出乎意料 的结果
如,上图的数据,我现在想把role_id为1的数据排到10的上面,但是,结果出乎了意料。
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` DESC
不能一遇到 这种问题, 就更改一次SQL语句?
如,上图的数据,我现在想把role_id为1的数据排到10的上面,但是,结果出乎了意料。
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` DESC
不能一遇到 这种问题, 就更改一次SQL语句?
desc是倒序,由大到小排列,10当然就排到1的前面了,role_id那里用asc
就是一个表里面有很多内容,我们需要把一些自认为很重要的内容通过人为的的干预,让他到指定的位置!!!
没有规则,很自由的让他“上”,“下”移动。给你所说的DISCUZ的排序不同,我们现在考虑的就一个字段,没有类型区分。只有数字的大小来判定这条内容他的位置。
应该是这样,说得比较凌乱。
如,上图的数据,我现在想把role_id为1的数据排到10的上面,但是,结果出乎了意料。
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` DESC
不能一遇到 这种问题, 就更改一次SQL语句?
desc是倒序,由大到小排列,10当然就排到1的前面了,role_id那里用asc
OK ,
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` ASC
你说是这样子是吗。
反之,我想把ID为10的排到ID为1的上面,请问该怎么做,不能老是去更改SQL?
如,上图的数据,我现在想把role_id为1的数据排到10的上面,但是,结果出乎了意料。
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` DESC
不能一遇到 这种问题, 就更改一次SQL语句?
desc是倒序,由大到小排列,10当然就排到1的前面了,role_id那里用asc
OK ,
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` ASC
你说是这样子是吗。
反之,我想把ID为10的排到ID为1的上面,请问该怎么做,不能老是去更改SQL?
如果你想人为指定,就写个函数,你想让10在1的上面,就传个10进这个函数,显示的时候让10在上面,想让1在上面是同样的道理。就是说,在显示的时候,进行控制。
如,上图的数据,我现在想把role_id为1的数据排到10的上面,但是,结果出乎了意料。
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` DESC
不能一遇到 这种问题, 就更改一次SQL语句?
desc是倒序,由大到小排列,10当然就排到1的前面了,role_id那里用asc
OK ,
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` ASC
你说是这样子是吗。
反之,我想把ID为10的排到ID为1的上面,请问该怎么做,不能老是去更改SQL?
如果你想人为指定,就写个函数,你想让10在1的上面,就传个10进这个函数,显示的时候让10在上面,想让1在上面是同样的道理。就是说,在显示的时候,进行控制。
关键是怎么去确定哪个在上面,哪个在下面。这是一个问题,?可以说说你的具体的办法么?
如,上图的数据,我现在想把role_id为1的数据排到10的上面,但是,结果出乎了意料。
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` DESC
不能一遇到 这种问题, 就更改一次SQL语句?
desc是倒序,由大到小排列,10当然就排到1的前面了,role_id那里用asc
OK ,
SELECT * FROM `tbl` ORDER BY `role_sort` DESC , `role_id` ASC
你说是这样子是吗。
反之,我想把ID为10的排到ID为1的上面,请问该怎么做,不能老是去更改SQL?
如果你想人为指定,就写个函数,你想让10在1的上面,就传个10进这个函数,显示的时候让10在上面,想让1在上面是同样的道理。就是说,在显示的时候,进行控制。
关键是怎么去确定哪个在上面,哪个在下面。这是一个问题,?可以说说你的具体的办法么?
这要看你自己定的规则了,你不是要通过人为的干预让“自认为”重要的内容到制定的位置吗?那你得先把规则搞清楚,然后才能根据规则出代码。明白吗?

DependencyInjection(DI)inPHPenhancescodeflexibilityandtestabilitybydecouplingdependencycreationfromusage.ToimplementDIeffectively:1)UseDIcontainersjudiciouslytoavoidover-engineering.2)Avoidconstructoroverloadbylimitingdependenciestothreeorfour.3)Adhe

到Improveyourphpwebsite的实力,UsEthestertate:1)emplastOpCodeCachingWithOpcachetCachetOspeedUpScriptInterpretation.2)优化的atabasequesquesquesquelies berselectingOnlynlynnellynnessaryfields.3)usecachingsystemssslikeremememememcachedisemcachedtoredtoredtoredsatabaseloadch.4)

是的,itispossibletosendMassemailswithp.1)uselibrarieslikeLikePhpMailerorSwiftMailerForeffitedEmailSending.2)enasledeLaysBetemailStoavoidSpamflagssspamflags.3)sylectynamicContentToimpovereveragement.4)

DependencyInjection(DI)inPHPisadesignpatternthatachievesInversionofControl(IoC)byallowingdependenciestobeinjectedintoclasses,enhancingmodularity,testability,andflexibility.DIdecouplesclassesfromspecificimplementations,makingcodemoremanageableandadapt

使用PHP发送电子邮件的最佳方法包括:1.使用PHP的mail()函数进行基本发送;2.使用PHPMailer库发送更复杂的HTML邮件;3.使用SendGrid等事务性邮件服务提高可靠性和分析能力。通过这些方法,可以确保邮件不仅到达收件箱,还能吸引收件人。

计算PHP多维数组的元素总数可以使用递归或迭代方法。1.递归方法通过遍历数组并递归处理嵌套数组来计数。2.迭代方法使用栈来模拟递归,避免深度问题。3.array_walk_recursive函数也能实现,但需手动计数。

在PHP中,do-while循环的特点是保证循环体至少执行一次,然后再根据条件决定是否继续循环。1)它在条件检查之前执行循环体,适合需要确保操作至少执行一次的场景,如用户输入验证和菜单系统。2)然而,do-while循环的语法可能导致新手困惑,且可能增加不必要的性能开销。

在PHP中高效地哈希字符串可以使用以下方法:1.使用md5函数进行快速哈希,但不适合密码存储。2.使用sha256函数提高安全性。3.使用password_hash函数处理密码,提供最高安全性和便捷性。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版
中文版,非常好用

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)