我编写了一个查询,以根据以下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
答案 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条件下转换数据