oracle ora 02290,ORACLE数据库之ORA-02290检查校验问题解析

2023-11-22 16:10

本文主要是介绍oracle ora 02290,ORACLE数据库之ORA-02290检查校验问题解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ORACLE数据库之ORA-02290检查校验问题解析

ORACLE数据库之ORA-02290检查校验问题解析

问题描述

首先是在开发需求迭代时,发现数据库某个非空字段需要修改成非必填类型。然后就一顿操作猛如虎(就是数据库直接把必输选项的对号取消了),测试环境一顿测试没问题,好了到了预生产环境,一开始就一片片报错:现实惨不忍睹,一片片啊。

Cause: java.sql.SQLIntegrityConstraintViolationException: ORA-02290: check constraint (TEST.SYS_C0016848) violated; ];

ORA-02290: check constraint (TEST.SYS_C0016848) violated

; nested exception is java.sql.SQLIntegrityConstraintViolationException: ORA-02290: check constraint (TEST.SYS_C0016848) violated

问题分析

由报错信息发现时某个字段不能为空被Oracle的检查校验拦住了,然后把所有的sql都打印出来单独执行还是报错。于是开始看这个检查校验具体是指的什么:select * from user_constraints where table_name='ONE_TEST', 发现报错的是TEST_ID字段不能为空,但是数据库是这样的:

799e5ead2d637ece86458e27fbb9443b.png

ed298ee57833c17005b637f53592793d.png

检查校验的表里面有两条TEST_ID IS NOT NULL的校验,当我取消勾选的时候 SYS_C0016851这个校验没了,但是16848还在,就像现在的环境中的报错。于是就有了一个质疑的地方是不是和建表语句有关。其实现在呢你把报错的检查校验删除掉问题就解决了。下面是验证自己的猜想。

问题复现

首先我在测试环境建一个表ONE_TEST如下图所示:

241253eb1833d30085753b22378d489b.png

CREATE TABLE "TESTTZ"."ONE_TEST" (

"ID" NUMBER NOT NULL ,

"INTERNAL_ID" VARCHAR2(40 BYTE) NOT NULL ,

"TEST_ID" VARCHAR2(40 BYTE) NOT NULL

)

ALTER TABLE "TESTTZ"."ONE_TEST" ADD CONSTRAINT "SYS_C0013346" PRIMARY KEY ("ID");

然后关键问题来了,导出建表语句如下所示,发现最后三行就是检查校验的内容,在把这个sql放到预生产环境执行后,查询相应的检查校验规则问题展现:

CREATE TABLE "TESTTZ"."ONE_TEST" (

"ID" NUMBER NOT NULL ,

"INTERNAL_ID" VARCHAR2(40 BYTE) NOT NULL ,

"TEST_ID" VARCHAR2(40 BYTE) NOT NULL

)

TABLESPACE "USERS"

LOGGING

NOCOMPRESS

PCTFREE 10

INITRANS 1

STORAGE (

INITIAL 65536

NEXT 1048576

MINEXTENTS 1

MAXEXTENTS 2147483645

BUFFER_POOL DEFAULT

)

PARALLEL 1

NOCACHE

DISABLE ROW MOVEMENT

;

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

-- Checks structure for table ONE_TEST

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

ALTER TABLE "TESTTZ"."ONE_TEST" ADD CONSTRAINT "SYS_C0016846" CHECK ("ID" IS NOT NULL) NOT DEFERRABLE INITIALLY IMMEDIATE NORELY VALIDATE;

ALTER TABLE "TESTTZ"."ONE_TEST" ADD CONSTRAINT "SYS_C0016847" CHECK ("INTERNAL_ID" IS NOT NULL) NOT DEFERRABLE INITIALLY IMMEDIATE NORELY VALIDATE;

ALTER TABLE "TESTTZ"."ONE_TEST" ADD CONSTRAINT "SYS_C0016848" CHECK ("TEST_ID" IS NOT NULL) NOT DEFERRABLE INITIALLY IMMEDIATE NORELY VALIDATE;

ae8ab8b51102e5b3cdcb3ff3c1ccaaef.png

每次执行建表语句会根据create 里面的参数类型的 not null创建新的检查校验规则到 user_constraints 里面,但是当我们直接把测试环境的建表语句导入到预生产环境的时候,预生产环境生成了新的检查校验规则,同时也把测试环境的检查校验规则插入到预生产环境的规则表里。再我们根据业务需要取消某个字段的非空选项时,仅仅取消了预生产环境新生成的检查校验规则,而测试环境的检查校验规则还存在,当插入字段为空时,就会报错。解决方案查出这个表所有的检查校验规则,ALTER TABLE TABLENAME DROP CONSTRAINT SYS_C0069731,删除即可。

如有披露或问题欢迎留言或者入群探讨

ORACLE数据库之ORA-02290检查校验问题解析相关教程

这篇关于oracle ora 02290,ORACLE数据库之ORA-02290检查校验问题解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/411336

相关文章

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente

Java实现数据库图片上传功能详解

《Java实现数据库图片上传功能详解》这篇文章主要为大家详细介绍了如何使用Java实现数据库图片上传功能,包含从数据库拿图片传递前端渲染,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、数据库搭建&nbsChina编程p; 3、后端实现将图片存储进数据库4、后端实现从数据库取出图片给前端5、前端拿到

IDEA连接达梦数据库的详细配置指南

《IDEA连接达梦数据库的详细配置指南》达梦数据库(DMDatabase)作为国产关系型数据库的代表,广泛应用于企业级系统开发,本文将详细介绍如何在IntelliJIDEA中配置并连接达梦数据库,助力... 目录准备工作1. 下载达梦JDBC驱动配置步骤1. 将驱动添加到IDEA2. 创建数据库连接连接参数

Flask解决指定端口无法生效问题

《Flask解决指定端口无法生效问题》文章讲述了在使用PyCharm开发Flask应用时,启动地址与手动指定的IP端口不一致的问题,通过修改PyCharm的运行配置,将Flask项目的运行模式从Fla... 目录android问题重现解决方案问题重现手动指定的IP端口是app.run(host='0.0.

Seata之分布式事务问题及解决方案

《Seata之分布式事务问题及解决方案》:本文主要介绍Seata之分布式事务问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Seata–分布式事务解决方案简介同类产品对比环境搭建1.微服务2.SQL3.seata-server4.微服务配置事务模式1

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete

MySql中的数据库连接池详解

《MySql中的数据库连接池详解》:本文主要介绍MySql中的数据库连接池方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql数据库连接池1、概念2、为什么会出现数据库连接池3、原理4、数据库连接池的提供商5、DataSource数据源6、DBCP7、C

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod