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;
相关推荐
清水白石00813 小时前
Fixture 的力量:pytest fixture 如何重新定义测试数据管理
数据库·python·pytest
Rick199315 小时前
如何保证数据库和Redis缓存一致性
数据库·redis·缓存
那个松鼠很眼熟w15 小时前
2.获取数据库连接
数据库
_ziva_16 小时前
5 分钟搭建 CSV 数据问答系统:LangChain + LLM 实战教程
jvm·数据库·oracle
JiaHao汤17 小时前
MySQL SQL 性能优化实战指南
sql·mysql·性能优化
dust_and_stars17 小时前
APT vs Snap vs Flatpak 核心对比表
运维·服务器·数据库
念越18 小时前
MySQL报错:Column count doesn‘t match value count at row 1 解决方案(超详细)
数据库·mysql
SmartBrain19 小时前
FastAPI实战(第二部分):用户注册接口开发详解
数据库·人工智能·python·fastapi
倔强的石头_20 小时前
一卡通核心交易平台的国产数据库实践解析:架构、迁移与高可用落地
数据库
9523620 小时前
MySQL存储过程和触发器
数据库·mysql