草庐IT

ordered_qty

全部标签

sql - 如何使用 ORDER BY 正确处理数字?

我想从mysql表中获取按其中一个varchar列排序的数据。假设我有这样的查询:SELECTname,modelFROMvehicleORDERBYmodel问题是,对于像这样的“模型”值:“S43”、“S111”,顺序将是:S111S43因为我想ORDERBY使用字母顺序规则,对吧?那么如何修改这个查询以获得“数字”订单呢?哪个“S43”会在“S111”之前?无需更改或向该表添加任何数据。 最佳答案 是这样的:SELECTname,modelFROMvehicleORDERBYCAST(TRIM(LEADING'S'FROMmo

MySQL ORDER BY 带负数的数值问题

我正在使用一个查询,它使用:ORDERBYscoreDESC;'score'只包含数值,也可以是负数。它们似乎没有按正确的顺序显示。负数可以出现在正数之上。有谁知道我应该使用这样的查询来显示它们:1051-1-5-10还要阻止他们这样做:*1*10*11*123*1234*2*25*253*34谢谢。 最佳答案 orderbycast(scoreasint)desc;看来您正在以字符串数据类型存储数字数据。最好将分数设为数字数据类型,例如int。 关于MySQLORDERBY带负数的数值

Mysql order by on column with unicode characters

我在mysql表上运行一个选择查询,并试图按表中的“名称”列对其进行排序。name列包含英文字符名称和带有拉丁字符的名称,如â.我遇到了以下问题。我运行的查询返回按以下方式排序的结果,即例如:如果名称包含“archer”、“aaakash”、“âhayden”、“bourne”、“jason”查询返回的结果排序如下“aaakash”、“archer”、“âhayden”、“bourne”、“jason”但是我想根据unicode代码点(如下所示)对其进行排序“aaakash”、“archer”、“bourne”、“jason”、“âhayden”(查看âhayden在命令中位置的不同)

MySQL 查询 ORDER BY 某些值先于其他值

我正在开发一个将完成时间存储在数据库中的游戏高分,但如果你没有完成关卡但保存你的高分,则完成时间为0。我正在尝试进行查询,首先列出完成时间最短的高分,但我的简单ORDERBY将所有0完成时间粘在类(class)开始时!有什么方法可以让我这样排序,但底部有0。我试过:SELECTFROMhighscoresORDERBYcompletiontime>0,completiontime=0ASC有人有什么想法吗? 最佳答案 SELECT*FROMhighscoresORDERBYcompletiontime=0,completiontim

mysql - ActiveRecord 查询 : order by a sum on an included model

项目有_many:itemsItembelongs_to:project我正在尝试按项目各自项目的总价对项目进行排序。像这样的东西:Project.includes(:items).order('SUM(items.price)')使用这段代码,ActiveRecord只返回第一个项目。我错过了什么? 最佳答案 我还没有尝试过v3的东西,但我认为它会是这样的Product.joins(:items).group('products.id').order('SUM(items.price)')

mysql - ORDER BY id 或 date_created 以显示最新结果?

我有一个表(实际上有几个),我想首先从中获取最新条目的结果。这是我的ORDERBY子句选项:date_createdINT(从不更改值)id(当然是INTAUTO_INCREMENT!)两列应该同样代表插入记录的顺序。我自然会像任何正常人一样使用date_created字段,但我仍然对此感到好奇。我知道这可能有点乱七八糟,但有什么理由或极端情况说明我不应该使用id列吗?编辑:我认为这个问题对于我们想要真正代表插入顺序的值是模糊的。谢谢大家的所有回答,我将接受最好的答案并继续前进,因为我认为我通过假设id始终有序(请参阅@Wrikken的评论)而使这变得困难。我的直觉是开发人员永远不应该

php - ORDERING 查询结果的问题

我目前构造一个id数组并使用implode查询这个数组,如下所示:$sql="SELECT*FROMitem_bank_tbWHEREitem_idIN(".implode(',',$ids).")";数组$ids的构造方式使得id具有特定的顺序。但是,此查询的结果不是按该顺序排列的。我猜,因为它们都在一个查询中,所以结果按它们所在的顺序(升序)出现。有没有办法解决这个问题?(除了包括一个我可以ORDERBY的字段)非常感谢。 最佳答案 看看这个例子。你必须使用field()函数。SELECT*FROMitem_bank_tbWHE

php - 1250 - 来自其中一个 SELECT 的表 'sub' 不能在全局 ORDER 子句中使用

我正在尝试制作一个用于学习目的的聊天网站,因此在此过程中,我希望最后30条消息按升序显示w.r.t.时间。比如,最新的消息在底部,最旧的消息在顶部。经过大量的谷歌搜索,但没有找到任何有帮助的解决方案,我不得不问这个问题。这是MySQL语句。它返回我想要的数据,但按降序排列。也就是说,最新的在顶部。即使我将ASC更改为DESC,也没有任何反应。SELECT*FROM(SELECTmsg,senderFROMchatlogsWHEREuser1='userone'ANDuser2='usertwo'ORDERBY'timeofmsg'DESCLIMIT30)subORDERBY'sub.t

php - 推进 2 : Using a subquery as the value for a virtual column

我们有一个包含所有产品的表格和一个包含所有订购商品的单独表格。订购的商品基本上是已订购产品的副本,与其源产品相关(通过外键)和仅与订购商品相关的附加数据,如订购数量。通过这种方式,我们确保了订单数据的一致性,因为即使我们将来可能会删除旧产品,旧订单仍然以订单项的形式包含所有已订购的产品。订单和订单商品通过一个简单的交叉引用表(如Propel文档中的表格)连接,只有两个字段:order_id和item_id。现在我必须实现一个功能来计算尚未发货的产品的订购数量,这样我们就可以跟踪我们的库存中有多少仍可供销售以及实际已经售出多少,但尚未发货。为此,我必须选择与给定源产品相关且仅属于未发货订

php - Laravel 在使用 CASE WHEN 时如何使用 order by?

我可以像这样在Laravel中使用orderBy方法:$posts=Post::orderBy('id','DESC')->get();好的,如果ORDERBY子句中有CASE怎么办?像这样:ORDERBYCASEWHENid.PinRequestCount0THEN5WHENid.HighCallAlertCount0THEN4WHENid.HighAlertCount0THEN3WHENid.MediumCallAlertCount0THEN2WHENid.MediumAlertCount0THEN1ENDdesc,我如何在Laravel中编写这个^?