零玖博客

ORA-01790: 表达式必须具有与对应表达式相同的数据类型

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 语句中的列的顺序必须相同

退出移动版