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;
相关推荐
我是一颗柠檬20 小时前
【MySQL全面教学】MySQL面试高频考点汇总Day15(2026年)
数据库·后端·mysql·面试
凯瑟琳.奥古斯特20 小时前
高阶子查询题目精炼
开发语言·数据库·python·职场和发展·数据库开发
身如柳絮随风扬20 小时前
数据库读写分离:从原理到实战,构建高并发系统
数据库·mysql
提笔了无痕21 小时前
RAG存储策略中.md格式的切片与存储怎么处理
数据库·ai·rag
陳土1 天前
DuckDB精读——基于Getting started with DuckDB
数据库·oracle
凯瑟琳.奥古斯特1 天前
数据库原理选择题精选
数据库·python·职场和发展
曹牧1 天前
C#:主线程能够捕获到子线程中的异常
开发语言·数据库·c#
朝阳5811 天前
MongoDB 副本集从零搭建到生产可用
数据库·mongodb
雨辰AI1 天前
SpringBoot3 整合达梦 DM9 超详细入门实战|从零搭建可直接上线
数据库·微服务·架构·政务