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;
相关推荐
zzh0815 小时前
MySQL高可用集群笔记
数据库·笔记·mysql
Shely20175 小时前
MySQL数据表管理
数据库·mysql
爬山算法5 小时前
MongoDB(80)如何在MongoDB中使用多文档事务?
数据库·python·mongodb
APguantou5 小时前
NCRE-三级数据库技术-第2章-需求分析
数据库·需求分析
寂夜了无痕6 小时前
MySQL 主从延迟全链路根因诊断与破局法则
数据库·mysql·mysql主从延迟
爱丽_6 小时前
分页为什么越翻越慢:offset 陷阱、seek 分页与索引排序优化
数据库·mysql
APguantou6 小时前
NCRE-三级数据库技术-第12章-备份与数据库恢复
数据库·sqlserver
Bat U6 小时前
MySQL数据库|表设计+新增+分组查询
数据库·mysql
麦聪聊数据7 小时前
企业数据流通与敏捷API交付实战(五):异构数据跨库联邦与零代码发布
数据库·sql·低代码·restful
Elastic 中国社区官方博客7 小时前
当 TSDS 遇到 ILM:设计不会拒绝延迟数据的时间序列数据流
大数据·运维·数据库·elasticsearch·搜索引擎·logstash