搜索
首页后端开发php教程排序的问题,请教高手。

本帖最后由 xviphackl 于 2013-07-30 16:14:18 编辑

在开发过程遇到了一个很纠结的问题。

就是我想把新发表的或在整个内容列表任意的位置的内容,移动到内容列表指定的位置!举个例子:

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在上面是同样的道理。就是说,在显示的时候,进行控制。


关键是怎么去确定哪个在上面,哪个在下面。这是一个问题,?可以说说你的具体的办法么?

这要看你自己定的规则了,你不是要通过人为的干预让“自认为”重要的内容到制定的位置吗?那你得先把规则搞清楚,然后才能根据规则出代码。明白吗?

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
PHP中的依赖注入:避免常见的陷阱PHP中的依赖注入:避免常见的陷阱May 16, 2025 am 12:17 AM

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

如何加快PHP网站:性能调整如何加快PHP网站:性能调整May 16, 2025 am 12:12 AM

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

通过PHP发送大规模电子邮件:有可能吗?通过PHP发送大规模电子邮件:有可能吗?May 16, 2025 am 12:10 AM

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

PHP中依赖注入的目的是什么?PHP中依赖注入的目的是什么?May 16, 2025 am 12:10 AM

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

如何使用PHP发送电子邮件?如何使用PHP发送电子邮件?May 16, 2025 am 12:03 AM

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

如何计算PHP多维数组的元素总数?如何计算PHP多维数组的元素总数?May 15, 2025 pm 09:00 PM

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

PHP中do-while循环有什么特点?PHP中do-while循环有什么特点?May 15, 2025 pm 08:57 PM

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

PHP中如何哈希字符串?PHP中如何哈希字符串?May 15, 2025 pm 08:54 PM

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

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

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

热工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

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

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)