0

我正在尝试合并三个表,每个表都应具有具有相同数据类型的相同列:

select *
from ALL_1
union all
select *
from ALL_2
union all
select *
from ALL_3
/

我不断收到“ORA-01790:表达式必须具有与相应表达式相同的数据类型”,因此显然其中一个表中的数据类型之一是不同的。每个表应该有 40 列。我想并排查看每列的数据类型,以便搜索差异。我该怎么做?

4

1 回答 1

0

在 SQL*Plus、SQL Developer、Toad 中,您可以使用 SQL*Plus 命令DESCRIBE

例如:

SQL> describe scott.emp

 Name                                              Null?    Type
 ------------------------------------------------- -------- ------------------------
 EMPNO                                             NOT NULL NUMBER(4)
 ENAME                                                      VARCHAR2(10)
 JOB                                                        VARCHAR2(9)
 MGR                                                        NUMBER(4)
 HIREDATE                                                   DATE
 SAL                                                        NUMBER(7,2)
 COMM                                                       NUMBER(7,2)
 DEPTNO                                                     NUMBER(2)

否则,您可以查询目录表。这种方法可能更好,因为您可以编写代码来为您进行检查(以准确找到差异所在),而不是手动进行。

SQL> select column_name, data_type, data_length, data_precision, data_scale
  2  from   all_tab_columns
  3  where  owner = 'SCOTT' and table_name = 'EMP'
  4  order by column_id;

COLUMN_NAME      DATA_TYPE          DATA_LENGTH DATA_PRECISION DATA_SCALE
---------------- ------------------ ----------- -------------- ----------
EMPNO            NUMBER                      22              4          0
ENAME            VARCHAR2                    10
JOB              VARCHAR2                     9
MGR              NUMBER                      22              4          0
HIREDATE         DATE                         7
SAL              NUMBER                      22              7          2
COMM             NUMBER                      22              7          2
DEPTNO           NUMBER                      22              2          0

8 rows selected.

例如,您可以在子句中添加和,并将TABLE_NAME子句更改为条件;添加然后检查输出 - 列应该出现在组中,首先来自所有三个表的第一列,然后来自所有三个表的第二列等。或者将代码写入, ,并查看哪些组的计数大于 1。COLUMN_IDSELECTWHEREIN (....)order by column_idcount(distinct data_type)group by column_id

于 2017-01-30T23:54:46.200 回答