Rails:查询按除 0 之外的数字对记录进行排序

2023-12-12

我根据优先级(升序)排列数据,其中“0”在优先级中被忽略。

下面是 Rails 查询:

Profile.where(active: true).order(:priority).pluck(:priority)

此查询返回优先级从“0”开始的有序记录列表

[0, 1, 1, 2, 2, 2, 2, 2, 3, 3, 3, 4, 4, 7]

您能否帮我弄清楚如何对数据进行排序,其中将带有“0”的记录添加到查询的最后,如下例所示。

Example: [1, 1, 2, 2, 2, 2, 2, 3, 3, 3, 4, 4, 7, 0]

您可以将字符串传递给#order使用原始 SQL,所以你可以说:

Profile.where(active: true)
       .order('case priority when 0 then 1 else -1 end, priority')
       .pluck(:priority)

强制优先级为零的条目结束。你不必使用1 and -1当然,作为数字,您可以使用任何您可读的内容并按正确的顺序排序,您甚至可以使用字符串(当然假设它们排序正确):

.order("case priority when 0 then 'last' else 'first' end, priority")
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Rails:查询按除 0 之外的数字对记录进行排序 的相关文章

随机推荐

  • Java - 将用户输入分配给变量/更改计数器

    尽管我对 C 有相当基本的了解 但我对 java 还很陌生 在我的作业中 我计算零钱并将其分类为美国货币 即 如果您有 105 美分 它将分为 1 美元和 1 毛钱 从逻辑上讲 我明白如何做到这一点 但我在理解 java 语法时遇到了一些严
  • ASP.NET MVC 框架 4.5 CSS 捆绑包无法在托管上运行

    我正在应用程序港口上运行一个用 MVC 4 编写的应用程序 一堆 css 文件不起作用 在我的本地计算机的调试模式下 我看到了应用程序的代码 并且看到了文件 该应用程序按预期工作 当我将应用程序上传到 Appharbor 时 我在代码中看到
  • 如何向水平 LinearLayout 添加(垂直)分隔线?

    我正在尝试将分隔线添加到水平线性布局中 但一无所获 分隔线只是不显示 我是 Android 新手 这是我的布局 XML
  • 如何将 Firebase Cloud Functions 调度程序与实时数据库/分析触发器结合使用?

    我正在开发 Firebase 云功能 以发送触发的推送通知 现在 只要用户在我的应用程序中触发 IAP 事件 我的函数就会发送推送 use strict const functions require firebase functions
  • 如何从 NSString 中删除十六进制字符

    我面临一个与字符串中的某些十六进制值相关的问题 我需要从字符串中删除十六进制字符 The problem is when i print object it prints as BLANK line And in debug mode it
  • java中如何将十六进制字符串转换为long?

    我想在java中将十六进制字符串转换为长字符串 我尝试过一般转换 String s 4d0d08ada45f9dde1e99cad9 long l Long valueOf s longValue System out println l
  • 极限算子的关系代数

    这两个 SQL 查询的关系代数是什么 Select from film where film rating PG limit 20 我们如何显示极限 Select from actor country where first name BO
  • 通用数据库设计方法

    我面对客户的应用程序如下所示 它允许最终用户输入 材料 对于这些材料 他们可以附加任意数量的 属性 属性可以具有任何类型的值 decimal int dateTime 和 varchar 长度从 5 个字符到大块文本不等 本质上 架构如下所
  • ios,从视图获取指向控制器的指针

    我正在尝试制作一个 ios UI 元素 我可以将屏幕上的项目拖动到 tableView 上 tableView 将添加相应的元素 我使用 hitTest 函数来识别我将元素拖动到哪个视图 并且工作正常 我的问题是 当我需要指向 tableV
  • 如何在 android 2.2 模拟器或 android 2.1 设备中使用地理编码器

    我需要使用地理编码器从 google map am 的地址获取 lang 和 lat am 在 android sdk 2 2 中工作 使用地理编码器无法正常工作 它会抛出异常 如何在我的应用程序中使用地理编码器 或任何其他可用于获取经度和
  • 无法在 Linux 上的 SQL Server 2017 Express 上启用 xp_cmdshell

    我正在尝试启用xp cmdshell在 Linux RedHat 7 4 上运行的 SQL Server 2017 Express 上 我正在跟进本指南 并出现以下错误 此版本不支持指定的选项 xp cmdshell SQL Server
  • 如何将私有 pdb 转换为公共 pdb?

    我有私有 pdb 文件 我必须将其转换为公共文件 有工具吗 Use PDBCopy pdbcopy 是 Windows 调试工具的一部分 可通过视窗软件开发工具包
  • 发生错误时如何不让 Flask 服务器崩溃? [关闭]

    Closed 这个问题需要多问focused 目前不接受答案 我使用flask制作了一个API应用程序 它接受一个数字 十进制 作为输入并返回一些字符串 如果我发送一个字符串 这个应用程序就会中断 并且在重新启动后可以正常工作 我不想每次在
  • Xcode 10 GM 多命令产生... Pods 问题

    刚刚切换到 xcode 10 Golden Master 并开始在我的一个 pod 中出现错误 FDTake Tried this线程 但我在构建阶段没有 plist 所以它不起作用 这个问题与 pod 有关吗 Showing All Me
  • getImageData 导致“未捕获错误:NOT_SUPPORTED_ERR:DOM 异常 9”

    我正在尝试了解 HTML5 中的一些图像处理 我发现当我尝试使用 getImageData 方法时 我会抛出此 JS 异常 我正在使用 Chrome 并在本地主机上运行 Thanks 好吧 找出问题所在了 我只想说 德普 我正在使用 get
  • 在 Python 中使用 BeautifulSoup 查找 html 标签

    我想在html代码中找到一个特定的标签 比如如果有2个标签 那么我怎样才能获取第二个标签的内容而不是第一个标签的内容 soup find id contact1 在这里是示例html代码 table align center th STUD
  • RestKit RKMappingTest JSON 数组

    我正在使用 RestKit gt 0 20 3 和 RestKit Testing gt 0 20 3 这是我的映射的一个示例 RKObjectMapping mapping RKObjectMapping mappingForClass
  • 使用数组中的参数调用函数 - apply() 而不使用上下文参数?

    是否有任何方法可以调用函数但设置上下文this当我通过执行以下操作调用该函数时它具有的 默认 值fn 此方法应该接受一个数组并将单个元素作为参数传递给函数 就像 apply 所做的那样 emitter new EventEmitter ar
  • 什么是 RSA 主机密钥?

    我收到这条消息说 将 IP 地址 192 30 252 130 的 RSA 主机密钥永久添加到已知主机列表中 RSA 密钥的含义是什么以及已知主机背后的概念是什么 RSA密钥是基于RSA算法的私钥 私钥用于在建立 SSL TLS 会话期间进
  • Rails:查询按除 0 之外的数字对记录进行排序

    我根据优先级 升序 排列数据 其中 0 在优先级中被忽略 下面是 Rails 查询 Profile where active true order priority pluck priority 此查询返回优先级从 0 开始的有序记录列表