ORACLE数据库巡检SQL脚本--7、检查不起作用的约束

用于识别不起作用的主键约束

一、SQL脚本

sql 复制代码
--检查不起作用的约束(禁用状态的主键约束)
SELECT OWNER, -- 约束所属用户
       CONSTRAINT_NAME, -- 约束名称
       TABLE_NAME, -- 约束对应的表
       CONSTRAINT_TYPE, -- 约束类型('P'代表主键约束)
       STATUS -- 约束状态('DISABLE'代表禁用)
  FROM DBA_CONSTRAINTS
 WHERE STATUS = 'DISABLE' -- 筛选禁用状态的约束
       AND CONSTRAINT_TYPE = 'P'; -- 仅筛选主键约束

二、脚本说明

该脚本的目标是识别处于禁用状态的主键约束

  • CONSTRAINT_TYPE = 'P':限定仅查询主键约束(主键是保证表记录唯一性、非空的核心约束);
  • STATUS = 'DISABLE':筛选"不起作用"的约束(禁用状态下,约束不会对表的DML操作生效)。
字段 含义 核心作用
OWNER 约束所属的数据库用户 定位该主键约束对应的业务用户
CONSTRAINT_NAME 主键约束的名称 后续启用约束的核心标识
TABLE_NAME 约束对应的表 明确是哪个表的主键约束被禁用
CONSTRAINT_TYPE 约束类型 此处固定为P(主键约束)
STATUS 约束状态 DISABLE表示约束当前不起作用

三注意事项

DISABLE表示约束当前不起作用

四、补充说明

1、禁用主键约束的影响

主键约束被禁用后,会破坏数据完整性:

  1. 数据重复/空值风险:表中可插入重复记录、或主键字段为空值,导致数据混乱;
  2. 外键依赖失效:依赖该主键的外键约束会无法正常校验,引发跨表数据不一致;
  3. 查询逻辑异常:依赖主键唯一性的业务逻辑(如关联查询、唯一标识)会出现错误。

2、处理建议

需先确保表中无重复/空值数据,再启用约束:

  1. 检查表中主键字段的有效性(无重复、非空):

    sql 复制代码
    SELECT [主键字段], COUNT(*) 
    FROM [OWNER].[TABLE_NAME]
    GROUP BY [主键字段]
    HAVING COUNT(*) > 1;  -- 若有结果,说明存在重复数据
  2. 启用主键约束:

    sql 复制代码
    ALTER TABLE [OWNER].[TABLE_NAME] ENABLE CONSTRAINT [CONSTRAINT_NAME];
    -- 示例:启用SCOTT用户EMP表的主键约束PK_EMP
    ALTER TABLE SCOTT.EMP ENABLE CONSTRAINT PK_EMP;
相关推荐
zzzzzz31019 小时前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab3 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神4 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据5 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_5 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡5 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧5 天前
Oracle EXPLAIN PLAN
数据库·oracle