首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PLS-00049:错误的绑定变量'NEW.NEW_SKILL_DESC‘

PLS-00049错误通常出现在Oracle数据库的PL/SQL代码中,表示尝试绑定一个不存在的变量。错误信息中提到的NEW.NEW_SKILL_DESC表明在触发器或存储过程中使用了NEW关键字来引用一个新插入或更新的行的列,但该列不存在或拼写错误。

基础概念

在Oracle数据库中,NEW关键字用于触发器中,代表将要插入或更新的数据行。当创建一个触发器时,可以使用NEW来引用即将被插入或更新的行的列值。

可能的原因

  1. 列名拼写错误NEW_SKILL_DESC列名可能拼写错误或不存在于相应的表中。
  2. 触发器定义错误:触发器可能被错误地定义在了不包含NEW_SKILL_DESC列的表上。
  3. 权限问题:当前用户可能没有足够的权限访问或修改该列。

解决方法

  1. 检查列名
    • 确认NEW_SKILL_DESC列确实存在于触发器关联的表中。
    • 使用DESCRIBE命令或查询USER_TAB_COLUMNS视图来查看表的列信息。
    • 使用DESCRIBE命令或查询USER_TAB_COLUMNS视图来查看表的列信息。
  • 修正触发器代码
    • 如果列名正确,检查触发器的定义,确保NEW关键字后跟的列名与表中的列名完全匹配。
    • 如果列名正确,检查触发器的定义,确保NEW关键字后跟的列名与表中的列名完全匹配。
  • 权限检查
    • 确保执行触发器的用户具有对表的INSERTUPDATE权限。
    • 确保执行触发器的用户具有对表的INSERTUPDATE权限。

应用场景

这种错误通常出现在需要使用触发器来自动处理数据插入或更新的场景中,例如:

  • 自动填充某些列的值。
  • 数据验证或清洗。
  • 记录审计日志。

示例代码

假设我们有一个名为employees的表,其中包含skill_desc列,我们想要创建一个触发器,在插入新记录时自动设置skill_desc的值。

代码语言:txt
复制
CREATE TABLE employees (
    id NUMBER PRIMARY KEY,
    name VARCHAR2(100),
    skill_desc VARCHAR2(255)
);

CREATE OR REPLACE TRIGGER trg_set_skill_desc
BEFORE INSERT ON employees
FOR EACH ROW
BEGIN
    :NEW.skill_desc := 'Default Skill Description';
END;
/

在这个例子中,如果skill_desc列名拼写错误为NEW_SKILL_DESC,就会触发PLS-00049错误。正确的做法是确保列名拼写正确,并且在触发器中正确引用。

通过上述步骤,应该能够解决PLS-00049错误。如果问题仍然存在,可能需要进一步检查数据库日志或咨询数据库管理员。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

查看时间戳类型的绑定变量

当我们需要找到某条使用绑定变量的SQL语句中具体用到的参数值时,通常会使用v$sql_bind_capture视图,如果是字符串类型的变量,直接检索即可, select sql_id, name, position...则是从vsql_bind_capture采集的,可以检索历史绑定变量的信息, 另外从《v和v_的一些玄机》和《同名的同义词和视图解惑》我们知道在Oracle中数据字典定义的名称,还是存在玄机的,vsql_bind_capture...因为在sqlplus下不能定义日期类型的变量,不好模拟绑定变量的情况, 我们在Java中,模拟传入一个Timestamp类型的绑定变量的场景, Timestamp c1 = new Timestamp...因此,在12c前,要看到Timestamp类型绑定变量参数的值,就得依靠ANYDATA,我们是可以从《PL/SQL Packages and Types Reference》找到对这个ANADATA的介绍...,例如能根据绑定变量值的类型,判断是否存在隐式转换。

4.7K30
  • 检查未绑定变量的语句(硬解析状况)

    上节我们介绍了如何通过Django获取Oracle 执行次数等于一的语句,而这些语句很有可能是未使用绑定变量导致,这节讲如何获取其具体的信息 ---- 开发环境 操作系统:CentOS 7.3 Python...则首先获取上节中查找到的执行次数等于一的语句, 5. 然后将语句作为参数传递到函数getunboundsql中未使用绑定变量的语句的相信信息,详情看具体代码 6....最后把页面的标题以及数据放到dic变量中传到 oracle_command_result_5.html模板文件中 ---- getunboundsql函数 这里的getunboundsql函数获取执行次数等于一的语句...cursor.execute(fp1) fp.close() row=s.fetchall() return row ---- getexecutions.sql 这个SQL获取v$sql视图中未使用绑定变量的语句情况...从上面结果我们可以看到这个select语句的where子句未使用绑定变量,从模块中可以看到其来自的哪里,载入时间也可以判断其执行的非常频繁。

    1.9K30

    js动态绑定事件,无法使用for循环中变量i的问题

    ❝小闫语录:我一直在幻想,那些伟大的预言家都来自未来,那些畅销小说家都是真实经历过... ❞ 每天不是在写 bug,就是在解 bug 的路上~更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选...』 1.问题描述 在一个 for 循环中,我动态给一堆 a 标签绑定 onclick 事件时,发现点击事件不正确。...但是上述代码点击每一个链接总是弹出一个值,而且还是个不正常的值。之所以说它不正常,是因为上面我获取到了 5 个标签,正常下标应该到 4 结束,但是总是弹出 5 ????...调用时,发现内部没有定义变量 i ,所以就去外面找一下,发现外层有,就取外层的值了,但是为什么是 5 呢?...那是因为 for 循环的结束条件是 i 不满足 i变量 i 的值就是 5,匿名函数到外层取值正好取到了它。

    3.9K10

    Salesforce学习 Lwc(十六)【track声明的变量与html项目绑定①】

    image.png Lwc自定义开发过程中,我们经常会用到【track】来声明变量,用来在html中表示它的值,例如下边在html的【lightning-input】标签中绑定js中的一个变量,然后在一个按钮事件中清空它...name; handleClick() { this.name = ''; } } image.png 第一遍输入框中输入【AAAAA】,然后点击×按钮,我们看到输入的值被正常清空了...原因分析: 第一次按下×按钮之后,变量【name】的值已经被清空,这时候我们输入【BBBBB】,然后按下×按钮,变量【name】的值又一次被清空,两次按下时,变量【name】的值并没有发生变化,所以页面没有被加载...我们可以每次输入时,都去重新给变量赋值,这样每次按下×按钮时,值都会发生变化,就可以解决这个问题。

    1.7K10

    Salesforce学习 Lwc(十七)【track声明的变量与html项目绑定②】

    image.png Lwc开发过程中,我们经常会遇到父子组件之间的相互调用,下边我们在子组件的【renderedCallback】中写一些逻辑,看看效果如何。...image.png 原因分析: 根据Log分析,【renderedCallback】方法并没有被执行,原因如图所示html中并没有绑定year变量,所以没有执行【renderedCallback】方法。...「year」的值变更 → 刷新 → 【renderedCallback 】方法内「eto」的设定 → 再刷新 → 【renderedCallback 】方法内「eto」的设定 → 「eto」的值没有发生变化...image.png 通过上边分析我们已经知道原因,如果html中不绑定year变量的情况下,要如何实现呢,下边我么放弃【renderedCallback】方法,然后使用year的Get,Set方法,试试看效果如何...etoDef[Number(year) % 12] : ''; } } 效果展示: image.png image.png 想象一下如果html中变量多的情况下,用这个方法会非常复杂,下边我们也可以用简便一点的方法去实现它

    1K10

    超多绑定变量导致异常的一个案例

    此时问题有两个, (1) 执行一次SQL为什么带着这么多绑定变量? (2) 为什么执行这么多绑定变量的SQL会导致数据库出现问题?...如果在同一条SQL或PL/SQL语句中使用超过65535个绑定变量,则数据库实例会因为ORA-7445的错误导致出现ORA-600,进而异常中断。...官方给出的方案,是打个12578873的patch,但是他只会解决因为绑定变量超多导致的实例终止的问题,超过65535绑定变量的语句还是不能执行,因此无论是workaround,还是终极解决,都是建议不要使用绑定变量超过...65535个,这就回到了第一个问题,超过65535个绑定变量的场景,合理么?...以及绑定变量的理解,如果只是会用,在很多场景下,能得到正确结果,但是碰到这种极端的场景,就会进坑。

    78130

    Oracle面对“数据倾斜列使用绑定变量”场景的解决方案

    甚至在有些老旧系统,由于在开始开发阶段缺乏认识没有使用到绑定变量,后期并发量增长且无法改造程序时,运维DBA还会不得已去设置cursor_sharing=force来强制使用系统的绑定变量(这是一个万不得已的方案...虽然使用绑定变量给OLTP系统带来了巨大的好处,但也同时带来一些棘手的问题,最典型的就是由于SQL文本中包含绑定变量,优化器无法知道绑定变量代表的具体值,只能使用默认的可选择率,这就可能导致由于无法准确判断值的可选择率而造成选择错误的执行计划...Oracle在9i时代就有了针对这个问题的解决方案,即绑定变量窥探(bind peeking)特性。...在这种背景下,咨询了公司SQL优化专家赵勇,建议是当遇到在数据倾斜的列上使用绑定变量的情况,应该及时与开发沟通,能否在这类数据分布严重倾斜的列上不用绑定变量,若该列上的值很多,不用绑定变量可能导致大量的硬解析的话...,还可在应用发出SQL前,先判断其传入的值,是否是非典型值,若不是的话,使用非绑定变量的SQL;若是典型值,则使用绑定变量的语句。

    1.8K20

    GDB读取动态库中定义的全局变量错误

    最近看了一篇getopt使用的文章,为了追踪其执行的逻辑,于是采用GDB挂载调试的方式进行查看。但却出现了GDB打印全局变量optind的时候出现错误。...问题发现和描述 首先optind是使用getopt时候的全局变量,表示使用getopt时候的下一个argv的指针索引。...也就是动态库中存在全局变量的时候,在编译阶段已经在程序的.BSS段中预留了控件给动态库中的全局变量,然后当程序初始化的时候,会拷贝动态库中的全局变量到程序预留的.BSS段控件;其他所有的动态库,也将访问通过前面所说的....BSS段中的全局变量来访问原先动态库中定义的全局变量。...回到原先的问题,那么GDB打印出来并不是程序中.BSS通过Copy Relocation产生的全局变量optind, 而是打印的libc.so中原有的变量的值。

    2.1K30

    当使用 jquery 插件操作 input 时同步 vue 中绑定的变量办法

    发表于2018-05-102019-01-01 作者 wind 为什么要同步到 vue 上绑定的变量呢,因为如果我们不更新绑定的变量的值,vue 下次刷新组件的时候,就会将旧的值更新到 input...我一般使用的方法是在 vue 中定义自定义指令,函数中可以获取到 vnode,有了 vnode 就可以获取vnode.context也就是 vue 对象,有了 vue 对象就可以将新的值设置到v-model...绑定的那个变量上,因为这是指令,还不确定有多少个地方使用到了这个指令,所以可以通过从 el 上获取到一些信息,来帮助获取对应的 v-model 对象。...例如下面这个自动完成的 jquery 插件的例子: Vue.directive('myautocomplete', { inserted: function (el,binding

    1.7K10

    JavaScript 中 this 的错误认识、绑定规则、常见问题讲解

    相信 Javascript 中的 this 会使很多同学在工作学习中产生困惑,笔者也同样是,经过阅读各种资料及实际工作中的应用,做了以下梳理,主要内容包括长期以来大家对 this 的错误认识及 this...两种错误认识 指向自身 this 的第一个错误认识是,很容易把 this 理解成指向函数自身,其实 this 的指向在函数定义阶段是无法确定的,只有函数执行时才能确定 this 到底指向谁,实际 this...is not a function 错误。...window.a,以下代码使用 var 声明的变量 a 会输出 1。...,而 let 就属于 ES6 规范了,但是 ES6 规范中 let、const、class 这些声明的全局变量,不再属于顶层对象的属性。

    60420

    一个执行计划异常变更的案例 - 外传之绑定变量窥探

    使用绑定变量除了以上可以避免硬解析的好处之外,还有其自身的缺陷,就是这种纯绑定变量的使用适合于绑定变量列值比较均匀分布的情况,如果绑定变量列值有一些非均匀分布的特殊值,就可能会造成非高效的执行计划被选择...但若绑定变量列分布不均匀,则绑定变量窥探的副作用会很明显,第二次以后的每次执行,无论绑定变量列值是什么,都会仅使用第一次硬解析窥探的参数值,这就有可能选择错误的执行计划,就像上面这个实验中说明的,第二次使用...简而言之,数据分布不均匀的列使用绑定变量,尤其在11g之前,受绑定变量窥探的影响,可能会造成一些特殊值作为检索条件选择错误的执行计划。...总结: 本文主要介绍了11g之前使用绑定变量和非绑定变量在解析效率方面的区别,以及绑定变量在绑定变量窥探开启的情况下副作用的效果。...虽然OLTP系统,建议高并发的SQL使用绑定变量,避免硬解析,可不是使用绑定变量就一定都好,尤其是11g之前,要充分了解绑定变量窥探副作用的原因,根据绑定变量列值真实分布情况,才能综合判断绑定变量的使用正确

    66330

    【快问快答】如何收集回看sql语句中传入的绑定变量值

    编者按: 本文作者系流浪的金鱼(花名),甲骨文数据库工程师。个人主页:https://blog.csdn.net/rishairu1,经其本人授权发布。...快问: 如何收集回看sql语句中传入的绑定变量值? 快答: 我们知道,当sql语句中有绑定变量的时候,如果需要回看传入的绑定变量值,可以通过 vsql_bind_capture 视图。...但是,vsql_bind_capture 视图是有限制的。...也就是说只有LONG,LOB,和ADT数据类型以外的,包含where语句或者having语句的sql,才能记录绑定变量值。那么除此以外的sql如何才能会看绑定变量值呢。 可以通过审计功能。...insert into emp (empno,ename) values (:v_empno,:v_ename) #1(3):700 #2(10): c h r i s 这样绑定变量值就被记录下来了

    1.8K30

    【DB笔试面试806】在Oracle中,如何查找未使用绑定变量的SQL语句?

    ♣ 题目部分 在Oracle中,如何查找未使用绑定变量的SQL语句?...♣ 答案部分 利用V$SQL视图的FORCE_MATCHING_SIGNATURE字段可以识别可能从绑定变量或CURSOR_SHARING获益的SQL语句。...换句话说,如果两个SQL语句除了字面量的值之外都是相同的,它们将拥有相同的FORCE_MATCHING_SIGNATURE,这意味着如果为它们提供了绑定变量或者CURSOR_SHARING,它们就成了完全相同的语句...所以,使用FORCE_MATCHING_SIGNATURE字段可以识别没有使用绑定变量的SQL语句。...⊙ 【DB笔试面试584】在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?⊙ 【DB笔试面试583】在Oracle中,什么是绑定变量分级?

    6.4K20

    临时变量作为非const的引用进行参数传递引发的编译错误

    :string&’ from a temporary of type ‘std::string’的错误。...其中文意思为临时变量无法为非const的引用初始化。也就是在参数传递的过程中,出现错误。...出错的代码如下: void print(string& str) { cout<<str<<endl; } //如此调用会报上面描述的错误 print("hello world"); 出错的原因是编译器根据字符串...当这个临时对象传递给非const的string&引用类型时,因为非const引用绑定对象时,要求该对象也是非const对象。而在这时,因为string类型的临时对象是const对象,所以就出现错误。...这里贴上摘自网上的一句话:“内置类型产生的临时变量具有常性,而自定义类型产生的临时变量不具有常性”,我想这句话能解释你所谓的临时变量为什么能作为左值的原因。”

    2.6K31

    【DB笔试面试584】在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?

    ♣ 题目部分 在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?...♣ 答案部分 当Oracle解析和执行含有绑定变量的目标SQL时,如果满足如下两个条件之一,那么该SQL中的绑定变量的具体输入值就会被Oracle捕获: l 当含有绑定变量的目标SQL以硬解析的方式被执行时...l 当含有绑定变量的目标SQL以软解析或软软解析的方式重复执行时,Oracle在默认情况下至少得间隔15分钟才会捕获一次。...,Oracle只会捕获那些位于目标SQL的WHERE条件中的绑定变量的具体输入值,而对于那些使用了绑定变量的INSERT语句,不管该INSERT语句是否是以硬解析的方式执行,Oracle始终不会捕获INSERT...语句的VALUES子句中对应绑定变量的具体输入值。

    3K40
    领券