关于desc的一个奇怪问题及分析

简介: 在平时的工作中,desc这个命令可谓短小精悍,可以很方便的查看表结构和not null的情况。 今天在生产环境中碰到一个有些奇怪的desc问题。 首先是数据迁移组说有一个表的constraint丢了。

在平时的工作中,desc这个命令可谓短小精悍,可以很方便的查看表结构和not null的情况。
今天在生产环境中碰到一个有些奇怪的desc问题。
首先是数据迁移组说有一个表的constraint丢了。但是在master中有。
这种问题有两种可能,一种就是constraint确实丢了。
另一种可能性就是创建的constraint的问题,可以参见: not null constraint和check constriant的问题及分析 http://blog.itpub.net/23718752/viewspace-1154073/

先来查看master中的情况,desc确实没有问题。
------details from master

 ********** TABLE columns INFO *****************

 

 COLUMN_ID COLUMN_NAME                    DATA_TYPE       DATA_LENGTH NULLABLE   DATA_DEFAULT

---------- ------------------------------ --------------- ----------- ---------- --------------------

         1 ID                             NUMBER(12,0)             22 N

         2 SYS_CREATION_DATE              DATE                      7 N

         3 SYS_UPDATE_DATE                DATE                      7 Y

         4 OPERATOR_ID                    NUMBER(9,0)              22 Y

         5 APPLICATION_ID                 CHAR(6)                   6 Y

         6 DL_SERVICE_CODE                CHAR(5)                   5 Y

         7 DL_UPDATE_STAMP                NUMBER(4,0)              22 Y

         8 TYPE                           VARCHAR2(30)             30 N

         9 CODE                           VARCHAR2(60)             60 N

        10 LANGUAGE                       VARCHAR2(30)             30 N

        11 DESCRIPTION                    VARCHAR2(180)           180 Y

        12 BE                             NUMBER(9,0)              22 N          0


 

********** CONSTRAINTS DETAILS INFO *****************

COLUMN_NAME          CONSTRAINT_NAME                C SEARCH_CONDITION                    DEFERRED  DEFERRABLE     RELY INDEX_NAME

-------------------- ------------------------------ - ----------------------------------- --------- -------------- ---- ------------------------------

BE                   AR1_GENE_BE_NN                 C "BE" IS NOT NULL                    IMMEDIATE NOT DEFERRABLE

LANGUAGE             AR1_GENE_LANGUAGE_NN           C "LANGUAGE" IS NOT NULL              IMMEDIATE NOT DEFERRABLE

CODE                 AR1_GENE_CODE_NN               C "CODE" IS NOT NULL                  IMMEDIATE NOT DEFERRABLE

TYPE                 AR1_GENE_TYPE_NN               C "TYPE" IS NOT NULL                  IMMEDIATE NOT DEFERRABLE

SYS_CREATION_DATE    AR1_GENE_SYS_CREATION_DATE_NN  C "SYS_CREATION_DATE" IS NOT NULL     IMMEDIATE NOT DEFERRABLE

ID                   AR1_GENE_ID_NN                 C "ID" IS NOT NULL                    IMMEDIATE NOT DEFERRABLE

TYPE                 AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

CODE                 AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

LANGUAGE             AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

BE                   AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

ID                   AR1_GENERIC_CODES_1UQ          U                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_1UQ

 

11 rows selected.

但是在有问题的用户下查看,desc确实有问题

---from issue db account

 COLUMN_ID COLUMN_NAME                    DATA_TYPE       DATA_LENGTH NULLABLE   DATA_DEFAULT

---------- ------------------------------ --------------- ----------- ---------- --------------------

         1 ID                             NUMBER(12,0)             22 Y

         2 SYS_CREATION_DATE              DATE                      7 Y

         3 SYS_UPDATE_DATE                DATE                      7 Y

         4 OPERATOR_ID                    NUMBER(9,0)              22 Y

         5 APPLICATION_ID                 CHAR(6)                   6 Y

         6 DL_SERVICE_CODE                CHAR(5)                   5 Y

         7 DL_UPDATE_STAMP                NUMBER(4,0)              22 Y

         8 TYPE                           VARCHAR2(30)             30 Y

         9 CODE                           VARCHAR2(60)             60 Y

        10 LANGUAGE                       VARCHAR2(30)             30 Y

        11 DESCRIPTION                    VARCHAR2(180)           180 Y

        12 BE                             NUMBER(9,0)              22 Y          0

但是奇怪的是constraint都在。

********** CONSTRAINTS DETAILS INFO *****************

 

 

COLUMN_NAME          CONSTRAINT_NAME                C SEARCH_CONDITION                    DEFERRED  DEFERRABLE     RELY INDEX_NAME

-------------------- ------------------------------ - ----------------------------------- --------- -------------- ---- ------------------------------

BE                   AR1_GENE_BE_NN                 C "BE" IS NOT NULL                    IMMEDIATE NOT DEFERRABLE

LANGUAGE             AR1_GENE_LANGUAGE_NN           C "LANGUAGE" IS NOT NULL              IMMEDIATE NOT DEFERRABLE

CODE                 AR1_GENE_CODE_NN               C "CODE" IS NOT NULL                  IMMEDIATE NOT DEFERRABLE

TYPE                 AR1_GENE_TYPE_NN               C "TYPE" IS NOT NULL                  IMMEDIATE NOT DEFERRABLE

SYS_CREATION_DATE    AR1_GENE_SYS_CREATION_DATE_NN  C "SYS_CREATION_DATE" IS NOT NULL     IMMEDIATE NOT DEFERRABLE

ID                   AR1_GENE_ID_NN                 C "ID" IS NOT NULL                    IMMEDIATE NOT DEFERRABLE

TYPE                 AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

CODE                 AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

LANGUAGE             AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

BE                   AR1_GENERIC_CODES_PK           P                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_PK

ID                   AR1_GENERIC_CODES_1UQ          U                                     IMMEDIATE NOT DEFERRABLE      AR1_GENERIC_CODES_1UQ

 

 那就排除了constraint丢失的情况了,查看是不是not null constraint的问题。

得到了对应的ddl语句,查看constraint是没有问题的。但是可以看到有一个奇怪的地方,就是constraint是disable的。

CREATE TABLE "xxxx"

    ("ID" NUMBER(12, 0) CONSTRAINT "AR1_GENE_ID_NN" NOT NULL DISABLE,

    "SYS_CREATION_DATE" DATE CONSTRAINT "AR1_GENE_SYS_CREATION_DATE_NN" NOT NULL DISABLE,

    "SYS_UPDATE_DATE" DATE,

    "OPERATOR_ID" NUMBER(9, 0),

    "APPLICATION_ID" CHAR(6),

    "DL_SERVICE_CODE" CHAR(5),

    "DL_UPDATE_STAMP" NUMBER(4, 0),

    "TYPE" VARCHAR2(30) CONSTRAINT "AR1_GENE_TYPE_NN" NOT NULL DISABLE,

    "CODE" VARCHAR2(60) CONSTRAINT "AR1_GENE_CODE_NN" NOT NULL DISABLE,

    "LANGUAGE" VARCHAR2(30) CONSTRAINT "AR1_GENE_LANGUAGE_NN" NOT NULL DISABLE,

    "DESCRIPTION" VARCHAR2(180),

    "BE" NUMBER(9, 0) CONSTRAINT "AR1_GENE_BE_NN" NOT NULL DISABLE)

    PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255

    STORAGE (INITIAL 1048576 NEXT 1048576 MINEXTENTS 1 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)

    TABLESPACE "DATAS01" LOGGING NOCOMPRESS

/

 

查看这个用户下constraint不为ENABLED的情况,这样可以查看还有没有类似的问题存在。但是如下的查询有些矛盾。很是蹊跷。
SQL> select constraint_name,status from user_constraints where status!='ENABLED';

no rows selected

 

查看有问题的表对应的constraint,查看constraint的状态,显示确实enabled.
SQL> select constraint_name,status from user_constraints where table_name='AR1_GENERIC_CODES';

CONSTRAINT_NAME                STATUS

------------------------------ --------

AR1_GENE_ID_NN                 ENABLED

AR1_GENE_SYS_CREATION_DATE_NN  ENABLED

AR1_GENE_TYPE_NN               ENABLED

AR1_GENE_CODE_NN               ENABLED

AR1_GENE_LANGUAGE_NN           ENABLED

AR1_GENE_BE_NN                 ENABLED

AR1_GENERIC_CODES_PK           ENABLED

AR1_GENERIC_CODES_1UQ          ENABLED

所以,从以上的排查,发现这是一个数据字典中的信息不匹配造成的,应该是oracle的一个bug,查看metalink没有找到相关的bug id.
但是问题不管怎么样都得解决,如果这是一个bug,就不能直接在生产中修改,万一出现严重问题就得不偿失了。
我采用的步骤如下:
从生产的备份库中导出这个表的dump,然后导入另外一个测试环境中,可以看到在测试环境这个问题可以复现。
修复之前使用desc查看。
SQL> desc ar1_generic_codes
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER(12)
 SYS_CREATION_DATE                                  DATE
 SYS_UPDATE_DATE                                    DATE
 OPERATOR_ID                                        NUMBER(9)
 APPLICATION_ID                                     CHAR(6)
 DL_SERVICE_CODE                                    CHAR(5)
 DL_UPDATE_STAMP                                    NUMBER(4)
 TYPE                                      NOT NULL VARCHAR2(30)
 CODE                                      NOT NULL VARCHAR2(60)
 LANGUAGE                                  NOT NULL VARCHAR2(30)
 DESCRIPTION                                        VARCHAR2(180)
 BE                                        NOT NULL NUMBER(9)


SQL> alter table ar1_generic_codes enable constraint AR1_GENE_ID_NN;
Table altered.

修复后,使用desc再次查看。
SQL> desc ar1_generic_codes
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                        NOT NULL NUMBER(12)
 SYS_CREATION_DATE                                  DATE
 SYS_UPDATE_DATE                                    DATE
 OPERATOR_ID                                        NUMBER(9)
 APPLICATION_ID                                     CHAR(6)
 DL_SERVICE_CODE                                    CHAR(5)
 DL_UPDATE_STAMP                                    NUMBER(4)
 TYPE                                      NOT NULL VARCHAR2(30)
 CODE                                      NOT NULL VARCHAR2(60)
 LANGUAGE                                  NOT NULL VARCHAR2(30)
 DESCRIPTION                                        VARCHAR2(180)
 BE                                        NOT NULL NUMBER(9)

如果再进一步查看这个问题,很有可能是在做goldengate同步的时候引入的。这个表在使用goldengate同步后没有做任何的结构变化。
但是要验证,需要得到更多的细节来验证。

目录
相关文章
|
2月前
|
SQL Java
一直傻傻分不清 count(*) count(id) count(1) 这次终于整明白了
一直傻傻分不清 count(*) count(id) count(1) 这次终于整明白了
24 0
|
SQL Oracle 关系型数据库
【SQL开发实战技巧】系列(五):从执行计划看IN、EXISTS 和 INNER JOIN效率,我们要分场景不要死记网上结论
从执行计划角度分析IN、EXISTS 和 INNER JOIN效率而不是死记网上结论、表的5种关联:INNER JOIN、LEFT JOIN、RIGHT JOIN 和 FULL JOIN 解析【SQL开发实战技巧】这一系列博主当作复习旧知识来进行写作,毕竟SQL开发在数据分析场景非常重要且基础,面试也会经常问SQL开发和调优经验,相信当我写完这一系列文章,也能再有所收获,未来面对SQL面试也能游刃有余~。
【SQL开发实战技巧】系列(五):从执行计划看IN、EXISTS 和 INNER JOIN效率,我们要分场景不要死记网上结论
|
SQL 数据挖掘 Python
SQL练习:2(简单)+1(中等),常规题(group by\order by\avg...)
SQL练习:2(简单)+1(中等),常规题(group by\order by\avg...)
163 0
SQL练习:2(简单)+1(中等),常规题(group by\order by\avg...)
|
数据库
【硬着头皮】 你别查询了,不就id么?
【硬着头皮】 你别查询了,不就id么?
【硬着头皮】 你别查询了,不就id么?
ORDER BY排序太简单?那是因为你还没用过这四大排序函数!
我们在写SQL代码时,只要有排序,首先想到的肯定是ORDER BY,以至于好多小伙伴觉得排序多简单啊。 今天就给大家介绍四个你不怎么常用排序函数,他们就是SQL Server排序中经常用到的ROW_NUMBER(),RANK(),DENSE_RANK(),NTILE()这四个好兄弟。
ORDER BY排序太简单?那是因为你还没用过这四大排序函数!
|
SQL Java 程序员
判断是否"存在",还在用count?试试这条SQL语句,性能杠杠的!
判断是否"存在",还在用count?试试这条SQL语句,性能杠杠的!
152 0
|
存储
关于SSMS显示select出来的数据行的疑问
原文:关于SSMS显示select出来的数据行的疑问   调试存储过程时,往往可以用print将存储过程中的变量print出来, 但是print出来的字符串有一定长度限制,刚才专门试了一下,应该是4000个字符 如果超过4000个字符,超长的字符会被自动截断,这一点应该比较清楚。
847 0