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

2021年3月1日 430点热度 1人点赞 0条评论

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

Gcod

人生若只如初见,何事秋风悲画扇

文章评论