ORA-01790: 表达式必须具有与对应表达式相同的数据类型
一、网上都是这么说的:
出现这种错误,要先看一下是不是 sql 中有用到连接:union,unio all 之类的,如果有,需要注意相同名称字段的数据类型一定要相同。
select a.time from A a union all select b.time from B b where a.name = b.name;
例如上现那句 sql, 要注意 A 和 B 中的 time 字段可能一个是 date 格式,一个是字符串格式,总之可能不是相同格式。一定要注意。
二、但是我还要补充一句
我写了两个 sql,使用 union all 连接。
select a.name a.age from studentTabA a union all select b.name b.age from studentTabB b
上述的语句是不会报错的,但是如果像下面这样写也还是会报 ORA-01790
select a.age a.name from studentTabA a union all select b.name b.age from studentTabB b
即 UNION 内部的每个 SELECT 语句必须拥有相同数量的列。
列也必须拥有相似的数据类型。
同时,每个 SELECT 语句中的列的顺序必须相同