• 关于 php排序desc 的搜索结果

问题

MySQL中排序字段值相等时 默认排序是什么逻辑

蛮大人123 2019-12-01 19:50:22 1246 浏览量 回答数 1

问题

PHP MySQL Order By 关键词

ethnicity 2019-12-01 22:08:30 7993 浏览量 回答数 0

问题

如何以固定坐标A,B为中心,1km为半径内的用户按照距离P远近进行排序?

落地花开啦 2019-12-01 20:02:41 1222 浏览量 回答数 1

新用户福利专场,云服务器ECS低至96.9元/年

新用户福利专场,云服务器ECS低至96.9元/年

回答

基本的一维数组 $array = array(3, 5, 2, 8); 适用的排序功能: sort rsort asort arsort natsort natcasesort ksort krsort 两者之间的区别仅在于是否保留键-值关联(“ a“函数),是否按从低到高或反向(” r“)排序,对值或键进行排序(” k“)以及如何比较值(“ nat”与正常)。有关概述以及指向更多详细信息的链接,请参见http://php.net/manual/zh-CN/array.sorting.php。 多维数组,包括对象数组 $array = array( array('foo' => 'bar', 'baz' => 42), array('foo' => ..., 'baz' => ...), ... ); 如果要按$array每个条目的键'foo' 进行排序,则需要一个自定义比较函数。上面sort和相关的函数处理简单的值,他们知道如何比较和排序。PHP不会简单地“知道”如何处理复杂的值,例如array('foo' => 'bar', 'baz' => 42);所以你需要告诉它。 为此,您需要创建一个比较函数。该函数需要两个元素,并且0如果这些元素被认为相等,则必须返回,该值要比0第一个值低时要低,而比第一个值高时要0高。这就是所需要的: function cmp(array $a, array $b) { if ($a['foo'] < $b['foo']) { return -1; } else if ($a['foo'] > $b['foo']) { return 1; } else { return 0; } } 通常,您将需要使用匿名函数作为回调。如果要使用方法或静态方法,请参见在PHP中指定回调的其他方法。 然后,您可以使用以下功能之一: usort uasort uksort 同样,它们只是在保留键值关联以及按值或键排序方面有所不同。阅读他们的文档以了解详细信息。 用法示例: usort($array, 'cmp'); usort将从数组中取出两项,并cmp用它们调用函数。因此cmp()将与$aas array('foo' => 'bar', 'baz' => 42)和$bas 一起调用array('foo' => ..., 'baz' => ...)。然后,函数返回到usort哪个值较大或它们是否相等。usort重复此过程,为传递不同的值$a,$b直到对数组排序为止。该cmp函数将被调用多次,至少被调用的次数与中的值的调用次数相同,并且每次调用的值的$array组合不同。$a$b 要习惯这个想法,请尝试以下操作: function cmp($a, $b) { echo 'cmp called with $a:', PHP_EOL; var_dump($a); echo 'and $b:', PHP_EOL; var_dump($b); } 您要做的就是定义一种自定义方式来比较两个项目,这就是您所需要的。这适用于各种价值。 顺便说一下,这适用于任何值,这些值不必是复杂的数组。如果您要进行自定义比较,则也可以对简单的数字数组进行比较。 sort 按引用排序,不返回任何有用的信息! 请注意,数组在适当的位置排序,您无需将返回值分配给任何对象。$array = sort($array)将用替换该数组true,而不用已排序的数组。只是sort($array);作品。 自定义数值比较 如果要按baz数字键进行排序,则需要做的是: function cmp(array $a, array $b) { return $a['baz'] - $b['baz']; } 多亏了数学运算的功率,它返回的值$a小于,等于0还是大于0,具体取决于是小于,等于还是大于$b。 请注意,这不适用于float值,因为它们会降低为int并失去精度。使用显式-1,0并1返回值。 对象 如果您有一个对象数组,则其工作方式相同: function cmp($a, $b) { return $a->baz - $b->baz; } 功能 您可以在比较函数内做任何需要的事情,包括调用函数: function cmp(array $a, array $b) { return someFunction($a['baz']) - someFunction($b['baz']); } 弦乐 第一个字符串比较版本的快捷方式: function cmp(array $a, array $b) { return strcmp($a['foo'], $b['foo']); } strcmp不正是要的是什么的cmp在这里,它返回-1,0或1。 飞船操作员 PHP 7引入了spaceship运算符,该运算符统一并简化了与跨类型比较相比相等/较小/​​较大的操作: function cmp(array $a, array $b) { return $a['foo'] <=> $b['foo']; } 按多个字段排序 如果要主要按排序foo,但如果foo两个元素相等,则按baz: function cmp(array $a, array $b) { if (($cmp = strcmp($a['foo'], $b['foo'])) !== 0) { return $cmp; } else { return $a['baz'] - $b['baz']; } } 对于熟悉的人,这等效于带有的SQL查询ORDER BY foo, baz。 另请参见此非常简洁的速记版本,以及如何为任意数量的键动态创建此类比较功能。 整理成手动,静态订单 如果要将元素按“手动顺序”排序,例如“ foo”,“ bar”,“ baz”: function cmp(array $a, array $b) { static $order = array('foo', 'bar', 'baz'); return array_search($a['foo'], $order) - array_search($b['foo'], $order); } 对于上述所有情况,如果您使用的是PHP 5.3或更高版本(确实应该使用),请对较短的代码使用匿名函数,并避免使另一个全局函数随处可见: usort($array, function (array $a, array $b) { return $a['baz'] - $b['baz']; }); 这就是对复杂的多维数组进行排序的简单方式。再次,只考虑在教授PHP时如何分辨两个项目中的哪个“更大”;让PHP进行实际排序。 同样对于以上所有内容,要在升序和降序之间切换,只需交换$a和$b参数即可。例如: return $a['baz'] - $b['baz']; // ascending return $b['baz'] - $a['baz']; // descending 根据另一数组对一个数组进行排序 然后是奇特的array_multisort,可让您根据另一个数组对一个数组进行排序: $array1 = array( 4, 6, 1); $array2 = array('a', 'b', 'c'); 这里的预期结果将是: $array2 = array('c', 'a', 'b'); // the sorted order of $array1 使用array_multisort到那里: array_multisort($array1, $array2); 从PHP 5.5.0开始,您可以array_column从多维数组中提取一列并对该列进行排序: array_multisort(array_column($array, 'foo'), SORT_DESC, $array); 从PHP 7.0.0开始,您还可以从对象数组中提取属性。 问题来源于stack overflow

保持可爱mmm 2020-01-16 14:54:07 0 浏览量 回答数 0

问题

关于php读取评论数,报错

一枚小鲜肉帅哥 2020-06-20 21:07:21 0 浏览量 回答数 1

回答

在派生表(子句内的子查询FROM)中,我们对数据user_id进行排序,以使所有具有相同值的行放在一起,并根据game_detail降序对它们进行进一步排序。 现在,我们使用此结果集并使用条件CASE..WHEN表达式来评估行编号。就像循环技术(我们在应用程序代码中使用的,例如:PHP)一样。我们将前一行的值存储在用户定义的变量中,然后对照前一行检查当前行的值。最终,我们将相应地分配行号。 编辑:基于MySQL 文档和@Gordon Linoff的观察: 涉及用户变量的表达式的求值顺序不确定。例如,不能保证SELECT @a,@a:= @ a + 1首先评估@a,然后执行分配。 我们将需要评估行号,并将user_id值分配给@u同一表达式中的变量。 SET @r := 0, @u := 0; SELECT @r := CASE WHEN @u = dt.user_id THEN @r + 1 WHEN @u := dt.user_id /* Notice := instead of = */ THEN 1 END AS user_game_rank, dt.user_id, dt.game_detail, dt.game_id FROM ( SELECT user_id, game_id, game_detail FROM game_logs ORDER BY user_id, game_detail DESC ) AS dt 结果 user_game_rankuser_idgame_detailgame_id162601126100101712001027500113726012475013 在数据库小提琴上查看 我最近发现了MySQL Docs的一个有趣的注释: MySQL的早期版本使得可以在SET以外的语句中为用户变量分配值。MySQL 8.0支持此功能以实现向后兼容,但是在将来的MySQL版本中可能会删除该功能。 另外,由于有一个SO成员,MySQL团队访问了此博客:https : //mysqlserverteam.com/row-numbering-ranking-how-to-use-less-user-variables-in-mysql-queries/ 通常的观察是,ORDER BY在同一查询块中与用户变量的评估一起使用时,并不能确保值始终正确。至于,MySQL优化可以接触到的地方,并改变我们的假设计算顺序。 解决此问题的最佳方法是升级到MySQL 8+并使用以下Row_Number()功能: 模式(MySQL v8.0) SELECT user_id, game_id, game_detail, ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY game_detail DESC) AS user_game_rank FROM game_logs ORDER BY user_id, user_game_rank; 结果 user_idgame_idgame_detailuser_game_rank611260161010027101200171150027122603713504来源:stack overflow

保持可爱mmm 2020-05-17 12:44:42 0 浏览量 回答数 0

回答

在派生表(子句内的子查询FROM)中,我们对数据user_id进行排序,以使所有具有相同值的行放在一起,并根据game_detail降序对它们进行进一步排序。 现在,我们使用此结果集并使用条件CASE..WHEN表达式来评估行编号。就像循环技术(我们在应用程序代码中使用的,例如:PHP)一样。我们将前一行的值存储在用户定义的变量中,然后对照前一行检查当前行的值。最终,我们将相应地分配行号。 编辑:基于MySQL 文档和@Gordon Linoff的观察: 涉及用户变量的表达式的求值顺序不确定。例如,不能保证SELECT @a,@a:= @ a + 1首先评估@a,然后执行分配。 我们将需要评估行号,并将user_id值分配给@u同一表达式中的变量。 SET @r := 0, @u := 0; SELECT @r := CASE WHEN @u = dt.user_id THEN @r + 1 WHEN @u := dt.user_id /* Notice := instead of = */ THEN 1 END AS user_game_rank, dt.user_id, dt.game_detail, dt.game_id FROM ( SELECT user_id, game_id, game_detail FROM game_logs ORDER BY user_id, game_detail DESC ) AS dt 结果 user_game_rankuser_idgame_detailgame_id162601126100101712001027500113726012475013 在数据库小提琴上查看 我最近发现了MySQL Docs的一个有趣的注释: MySQL的早期版本使得可以在SET以外的语句中为用户变量分配值。MySQL 8.0支持此功能以实现向后兼容,但是在将来的MySQL版本中可能会删除该功能。 另外,由于有一个SO成员,MySQL团队访问了此博客:https : //mysqlserverteam.com/row-numbering-ranking-how-to-use-less-user-variables-in-mysql-queries/ 通常的观察是,ORDER BY在同一查询块中与用户变量的评估一起使用时,并不能确保值始终正确。至于,MySQL优化可以接触到的地方,并改变我们的假设计算顺序。 解决此问题的最佳方法是升级到MySQL 8+并使用以下Row_Number()功能: 模式(MySQL v8.0) SELECT user_id, game_id, game_detail, ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY game_detail DESC) AS user_game_rank FROM game_logs ORDER BY user_id, user_game_rank; 结果 user_idgame_idgame_detailuser_game_rank611260161010027101200171150027122603713504来源:stack overflow

保持可爱mmm 2020-05-17 20:18:32 0 浏览量 回答数 0

问题

技术运维问题 - MYSQL使用 -RDS实例CPU超过100%的分析

李沃晟 2019-12-01 21:43:15 1008 浏览量 回答数 0

问题

【阿里云产品公测】简单日志服务SLS使用评测含教程

mr_wid 2019-12-01 21:08:11 36639 浏览量 回答数 20
阿里云大学 云服务器ECS com域名 网站域名whois查询 开发者平台 小程序定制 小程序开发 国内短信套餐包 开发者技术与产品 云数据库 图像识别 开发者问答 阿里云建站 阿里云备案 云市场 万网 阿里云帮助文档 免费套餐 开发者工具 云栖号物联网 小程序开发制作 视频内容分析 企业网站制作 视频集锦 代理记账服务 2020阿里巴巴研发效能峰会 企业建站模板 云效成长地图 高端建站 云栖号弹性计算 阿里云云栖号 云栖号案例 云栖号直播