Oracle SQL在IN子句中传递单引号

时间:2019-05-20 04:55:02

标签: sql oracle

我编写了一个查询,以根据以下ID过滤一些记录。问题是emp_id在一个表中定义为Number,而另一个具有Varchar。我需要在“条款”中使用单引号

SELECT   emp_id, sal, name
from EMP1 -- here emp_id is defined as varchar 
where
 emp_id IN( Q'[Select empid from emp2]')-- as you can see i tried q'[]' to escape single quotes and doesn't work

2 个答案:

答案 0 :(得分:3)

您尝试执行的操作没有任何意义,而只是将字符串文字SQL查询放入IN子句中,而不是将所有来自{{1}的empid值}表。相反,只需使用常规子查询,然后在emp2表中的TO_NUMBER上调用emp_id,以使其与EMP1表中的empid进行正确比较。

emp2

如果以上查询仍然给您带来问题,则可能暗示SELECT emp_id, sal, name FROM EMP1 WHERE TO_NUMBER(emp_id) IN (SELECT empid FROM emp2); 中的某些数据不是正确的数字,或者至少不是emp_id可以解析的数据。在这种情况下,您可以尝试将子查询中的TO_NUMBER值强制转换为character:

empid

答案 1 :(得分:1)

使用INNER JOIN可以避免使用IN子句

  SELECT   emp_id, sal, name
  from EMP1 
  INNER JOIN EMP2 ON TO_CHAR(EMP2.empid) = EMP1.emp_id 

您可以在ON条件下转换数据