首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >Rails SQL "select in“跨几个列: where (code1,code2) in ("A",1),(”A“,3),("Q",9))

Rails SQL "select in“跨几个列: where (code1,code2) in ("A",1),(”A“,3),("Q",9))
EN

Stack Overflow用户
提问于 2018-05-03 10:21:07
回答 2查看 103关注 0票数 2

我有一个业务要求根据一个表中的两个字段选择记录: code1和code2。选择是复杂和硬编码,没有可编码的押韵或理由,并包括大约十几对,在表中实际存在的100对。

  • C,1
  • C,2
  • J,9
  • Z,0

请注意,表中还有其他"C“代码,如(C,3)。没有组合字段将它们都捕获为值,例如"C3“。

SQL支持这样的查询:Two columns in subquery in where clause

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SELECT * from rejection_codes
  where (code1, code2) in (("A", 1), ("A", 3), ("Q", 9))

有什么方法可以在Rails和ActiveRecord的ORM中做到这一点,而无需使用原始SQL呢?

如果重要的话,我正在使用Postgres运行Rails 4.2.9。

*你为什么不..。*

添加一个字段:我无法控制数据库模式。如果是这样的话,我会为这个组添加一个新的列作为标志。或将值连接到字符串中的计算列。或者别的什么..。可是,我不会呀。

使用原始SQL:是的.如果我不能通过ORM完成的话,我可能会这么做。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-05-03 11:36:38

如果你想要的正是这样的结构,那么你可以这样做:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
pairs = [['A', 1], ['A', 3], ['Q', 9]]
RejectionCode.where('(code1, code2) in ((?), (?), (?))', *pairs)

当然,pairs.length不一定总是三岁,所以您可以这样说:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
pairs = [['A', 1], ['A', 3], ['Q', 9]]
placeholders = (%w[(?)] * pairs.length).join(', ')
RejectionCode.where("(code1, code2) in (#{placeholders})", *pairs)

是的,这是使用字符串内插来构建SQL片段,但是在这种情况下它是完全安全的,因为您正在构建所有的字符串,并且您确切地知道其中包含了什么。如果你把它放到一个范围里,那么至少丑陋会被隐藏起来,你可以很容易地用你的测试套件来覆盖它。

或者,你也可以利用一些等价的。in是一种奇特的or,因此它们所做的事情大致相同:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
c in (x, y, z)
c = x or c = y or c = z

而且记录(甚至匿名记录)是逐列比较的,因此它们是等价的:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
(a, b) = (x, y)
a = x and b = y

这意味着像这样的事情:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
pairs = [['A', 1], ['A', 3], ['Q', 9]]
and_pair = ->(a) { RejectionCode.where('code1 = ? and code2 = ?', *a) }
and_pair[pairs[0]].or(and_pair[pairs[1]]).or(and_pair[pairs[2]])

会给你同样的结果。或更广泛地说:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
pairs = [['A', 1], ['A', 3], ['Q', 9], ... ]
and_pair = ->(a) { RejectionCode.where('code1 = ? and code2 = ?', *a) }
query = pairs[1..-1].inject(and_pair[pairs.first]) { |q, a| q.or(and_pair[a]) }

再说一次,你会想把这个丑陋隐藏在一个范围里。

票数 1
EN

Stack Overflow用户

发布于 2018-05-03 11:34:03

*这是一个不错的解决办法,但并不能完全解决ORM问题*

在ActiveRecord中找不到正确的方法来做到这一点,我只是猜到了,希望是最好的:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class ApprovalCode < ActiveRecord::Base

  REJECTION_CODES = [
    ['A', '0'],
    ['R', '1'],
    ['R', '5'],
    ['R', '6'],
    ['X', 'F'],
    ['X', 'G']
  ]

  scope :rejection_allowed, -> { where([:code, :sub_code], REJECTION_CODES) }  # This didn't work.

end

那不起作用。因此,我在作用域中使用了原始SQL,这确实有效:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  scope :rejection_allowed, -> { where("(code, sub_code) in (#{rejection_list})") }

  def self.rejection_list
    REJECTION_CODES
      .map{|code, sub_code| "('#{code}', '#{sub_code}')"}
      .join(', ')
  end

我仍然希望在ORM中找到如何做到这一点,或者阅读关于完全不同的方法来解决这个问题的建议。因为它都封装在一个作用域和一个常量中,以后重构就很简单了,将常量和作用域分开将允许进行无痛测试。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50161583

复制
相关文章
GoogleMaps api for javascript demo 动态按顺序加载marker
@{ } <!DOCTYPE html> <html lang="zh"> <head> <meta name="viewport" content="initi
阿新
2018/04/12
8040
JavaScript 将对象数组按字母顺序排序
Chrome、IE、Edge、Firefox、Safari、Opera 等 都支持 sort() 方法。
唐志远
2023/07/26
6330
JavaScript 将对象数组按字母顺序排序
JavaScript 将对象数组按字母顺序排序
1.if条件语句 + sort() 2.localeCompare() + sort() 3.Collator() + sort()
唐志远
2023/08/01
2610
JavaScript 将对象数组按字母顺序排序
junit方法按顺序执行
选定版本,直接加注解
IT云清
2021/12/06
1.3K0
junit方法按顺序执行
sql按顺序去重
参考博客: https://blog.csdn.net/qtvb1987/article/details/42081585
周杰伦本人
2022/10/25
8450
sql按顺序去重
数组按指定顺序排序
数组排序可以直接使用 sort() 方法,可以对数组按规律排序。 但如果指定一个没有规律的顺序进行排序呢? 同样可以使用  sort() 方法: const data = [   { name: '张三', code: 'zs' },   { name: '王五', code: 'ww' },   { name: '赵七', code: 'zq' }, ]; data.sort((star, next) => {   const sortList = ['zq', 'zs', 'ww']   return 
德顺
2022/06/12
2.7K0
HTML加载顺序
完成了若干个基于WEB的项目, 也了解了从前端的js,css,html到后端python/php等, 二者如何交互, 最终浏览器如何执行, 这些在心里也已经很明确了. 不过一个问题一直萦绕在心中,那就是:
用户7657330
2020/08/14
1.9K0
vue for循环中按顺序axios请求拿到每条数据对应的状态
在循环数组的时候基于每个对象中的某个参数来进行数据请求,获取当前对象对应的数据状态 实现方法基于最新的es6中的async await 来实现 首先要把对应的Promise方法进行一个封装
李维亮
2021/07/08
1.9K0
实现线程按顺序输出ABC
线程按顺序输出ABC 实现描述:建立三个线程A、B、C,分别按照顺序输出十次ABC 首先建立一个方法,按照条件进行输出 class PrintABC{ private int index=0; public synchronized void print(int n) { // TODO Auto-generated method stub try { while(index!=n) { wait(); } if(index==0) { System.out.
呆呆
2021/10/06
7810
JavaScript 按值传递 & 按引用传递
其次,对象的比较并非值的比较:对象的比较均是引用的比较,当且仅当它们引用同一个基对象时,它们才相等。     即使两个对象包含同样的属性和相同的值,它们也是不相等的。各个索引元素完全相等的两个数组也不相等
书童小二
2018/09/03
3.8K0
Javascript - 事件顺序
原文标题:Javascript - Event order 原文链接:https://www.quirksmode.org/js/events_order.html Netscape 4 只支持事件捕获,Explorer只支持事件冒泡。Netscape 6和 Konqueror冒泡和捕获均支持,但Opera 和iCab冒泡和捕获均不支持。 在介绍事件的那篇文章(文章链接:https://www.quirksmode.org/js/introevents.html)中,我提了个看起来比较难以理解的问题:“
崔庆才
2018/06/25
1K0
hive-行转列按顺序合并
目录 一、背景 二、实现 1.建表ddl 2.示例数据 3.按顺序合并 4.按顺序合并结果 5.可以看到最后一条最长的才是我们需要的数据 6.结果 ---- ---- 一、背景 想实现行转列按顺序合并,但是impala不支持,故用hive实现 二、实现 1.建表ddl create table a( id bigint comment '主键', type bigint comment '分类', start_time bigint comment '开始时间,时间戳', end_time big
chimchim
2022/11/13
2.1K0
hive-行转列按顺序合并
java | 如何让线程按顺序执行?
本文使用了8种方法实现在多线程中让线程按顺序运行的方法,涉及到多线程中许多常用的方法,不止为了知道如何让线程按顺序运行,更是让读者对多线程的使用有更深刻的了解。使用的方法如下:
JavaFish
2019/10/16
6.5K0
Java类加载的顺序
那一年,呼延十又回想起被加载顺序支配的恐惧,笔试题上,好几个类,几个方法,几个输出语句,让你按照顺序写出输出.我真的是有一句….
呼延十
2019/07/01
1.3K0
java变量的加载顺序
学习编程思想 1 package com.test.java.classs; 2 3 /** 4 * Created by Administrator on 2015/12/7. 5 * 在类的内部,变量定义的顺序决定了初始化的顺序。 6 * 变量会在任何方法(包含构造器)被调用之前得到初始化 7 */ 8 public class Variable { 9 public static void main(String[] args) { 10 House
Ryan-Miao
2018/03/13
1.1K0
javascript按位异或(^)[通俗易懂]
大家好,又见面了,我是你们的朋友全栈君。<script type=”text/javascript”> var num1=25; var num2=3; alert(num1^num2);//输出: 26 ;对两个数值的二进制写法进行比较,只有当相同位置上的数字只有一个1时,才返回1,有两个1或者都是0则返回0,然后转换成十进制数值; </script>
全栈程序员站长
2022/09/06
8460
让线程按顺序执行 8 种方法
本文使用了8种方法实现在多线程中让线程按顺序运行的方法,涉及到多线程中许多常用的方法,不止为了知道如何让线程按顺序运行,更是让读者对多线程的使用有更深刻的了解。使用的方法如下:
业余草
2019/09/18
2K0
让线程按顺序执行 8 种方法
web.xml 组件加载顺序
在配置项目组件的过程中, 了解Tomcat加载组件顺序很有必要。 例如某些框架如Quartz的集群功能需要数据库的支持, 数据库的加载肯定要在框架组件加载之前。
用户1257393
2018/07/30
8020
web.xml 组件加载顺序
在配置项目组件的过程中, 了解Tomcat加载组件顺序很有必要。 例如某些框架如Quartz的集群功能需要数据库的支持, 数据库的加载肯定要在框架组件加载之前。
用户1257393
2018/07/30
8930
点击加载更多

相似问题

按顺序加载JavaScript脚本

64

按特定顺序获取api请求

22

JavaScript按顺序获取多个请求

11

如何强制JavaScript按顺序加载?

11

Javascript承诺按反向顺序加载

14
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文