婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Oracle查詢sql錯誤信息的控制和定位

Oracle查詢sql錯誤信息的控制和定位

熱門標簽:貴陽電話外呼系統哪家好 400電話是不是免費申請 安陽外呼系統免費 分布式呼叫中心 呼倫貝爾智能手機地圖標注 濟南地圖標注公司 南寧人工智能電銷機器人費用 海南400電話哪里辦理 圖像地圖標注

在sqlplus中執行的sql出錯之后應該如何處理和對應,多行sql語句或者存儲過程的信息如何進行錯誤定位,這篇文章將結合實例進行簡單地說明。

環境準備

使用Oracle的精簡版創建docker方式的demo環境,詳細可參看:

  • https://www.jb51.net/article/153533.htm

如何進行錯誤定位

場景:

假如有3行insert的sql語句,中間一行出錯之后,后續繼續執行的情況下,如何定位到第二行?

dbms_utility.format_error_backtrace

通過使用dbms_utility.format_error_backtrace可以得到ERROR at line xxx:的信息,這對我們較為有用,我們接下來進行確認

oracle@e871d42341c0:~$ sqlplus system/abcd1234@XE EOF
> SET SERVEROUTPUT ON
> desc student
> delete from student;
> select * from student;
> insert into student values (1001, 'liumiaocn');
> insert into student values (1001, 'liumiao');
> insert into student values (1003, 'michael');
> select * from student;
> commit;
> exec dbms_output.put_line(dbms_utility.format_error_backtrace);
> EOF
SQL*Plus: Release 11.2.0.2.0 Production on Sun Oct 21 13:06:07 2018
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
SQL> SQL> Name    Null?  Type
 ----------------------------------------- -------- ----------------------------
 STUID    NOT NULL NUMBER(4)
 STUNAME     VARCHAR2(50)
SQL> 
2 rows deleted.
SQL> 
no rows selected
SQL> 
1 row created.
SQL> insert into student values (1001, 'liumiao')
*
ERROR at line 1:
ORA-00001: unique constraint (SYSTEM.SYS_C007024) violated
SQL> 
1 row created.
SQL> 
   STUID STUNAME
---------- --------------------------------------------------
   1001 liumiaocn
   1003 michael
SQL> 
Commit complete.
SQL> 
PL/SQL procedure successfully completed.
SQL> Disconnected from Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
oracle@e871d42341c0:~$ 

可以看到,報錯的時候提示了行號,但是行號是1,這是因為這種寫法以一行為單位,自然是如此,如果是單個多行的存儲過程,將會更加清晰。

ERROR at line 1:
ORA-00001: unique constraint (SYSTEM.SYS_C007024) violated

所以我們將這個例子進行改造,三行insert的sql放到文件之中,然后在使用dbms_utility.format_error_backtrace來進行確認

oracle@e871d42341c0:~$ cat /tmp/sqltest1.sql 
desc student
delete from student;
select * from student;
insert into student values (1001, 'liumiaocn');
insert into student values (1001, 'liumiao');
insert into student values (1003, 'michael');
select * from student;
commit;
oracle@e871d42341c0:~$

然后在嘗試一下是否能夠確認行號,會發現仍然不能精確定位:

oracle@e871d42341c0:~$ sqlplus system/abcd1234@XE EOF
> SET SERVEROUTPUT ON
> @/tmp/sqltest1.sql
> exec dbms_output.put_line(dbms_utility.format_error_backtrace);
> EOF
SQL*Plus: Release 11.2.0.2.0 Production on Sun Oct 21 13:08:27 2018
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
SQL> SQL> Name    Null?  Type
 ----------------------------------------- -------- ----------------------------
 STUID    NOT NULL NUMBER(4)
 STUNAME     VARCHAR2(50)
2 rows deleted.
no rows selected
1 row created.
insert into student values (1001, 'liumiao')
*
ERROR at line 1:
ORA-00001: unique constraint (SYSTEM.SYS_C007024) violated
1 row created.
   STUID STUNAME
---------- --------------------------------------------------
   1001 liumiaocn
   1003 michael
Commit complete.
SQL> 
PL/SQL procedure successfully completed.
SQL> Disconnected from Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
oracle@e871d42341c0:~$ 

因為dbms_utility.format_error_backtrace更多的場景是在于存儲過程的錯誤定位,接下來我們使用一個簡單的存儲過程例子來進行確認錯誤行號定位, 先看一個正常的存儲過程,把上面的內容稍微修改一下:

oracle@e871d42341c0:~$ cat /tmp/addstudent.sql 
create or replace PROCEDURE addstudents
IS
student_count number;
BEGIN
delete from student;
select count(*) into student_count from student;
dbms_output.put('sql set count before :');
dbms_output.put_line(student_count);
insert into student values (1001, 'liumiaocn');
insert into student values (1002, 'liumiao');
insert into student values (1003, 'michael');
select count(*) into student_count from student;
dbms_output.put('sql set count after :');
dbms_output.put_line(student_count);
END;
/
exec addstudents();
oracle@e871d42341c0:~$

結果執行信息如下

oracle@e871d42341c0:~$ sqlplus system/liumiao123 EOF
set serveroutput on;
@/tmp/addstudent.sql 
EOF
SQL*Plus: Release 11.2.0.2.0 Production on Mon Oct 22 04:42:11 2018
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
SQL> SQL> 
Procedure created.
sql set count before :0
sql set count after :3
PL/SQL procedure successfully completed.
SQL> Disconnected from Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
oracle@e871d42341c0:~$ 

接下來我們修改一下內容,使得第二行主鍵重復

oracle@e871d42341c0:~$ cat /tmp/addstudent.sql
create or replace PROCEDURE addstudents
IS
student_count number;
BEGIN
delete from student;
select count(*) into student_count from student;
dbms_output.put('sql set count before :');
dbms_output.put_line(student_count);
insert into student values (1001, 'liumiaocn');
insert into student values (1001, 'liumiao');
insert into student values (1003, 'michael');
select count(*) into student_count from student;
dbms_output.put('sql set count after :');
dbms_output.put_line(student_count);
END;
/
exec addstudents();
oracle@e871d42341c0:~$ 

再次執行,自然會出錯,但是可以看到,正確報出了所在行數,這是procedure的機制提示的信息

oracle@e871d42341c0:~$ sqlplus system/liumiao123 EOF
set serveroutput on;
@/tmp/addstudent.sql 
EOF
SQL*Plus: Release 11.2.0.2.0 Production on Mon Oct 22 04:44:25 2018
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
SQL> SQL> 
Procedure created.
sql set count before :0
BEGIN addstudents(); END;
*
ERROR at line 1:
ORA-00001: unique constraint (SYSTEM.SYS_C007024) violated
ORA-06512: at "SYSTEM.ADDSTUDENTS", line 10
ORA-06512: at line 1
SQL> Disconnected from Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
oracle@e871d42341c0:~$

可以看到,ORA-06512: at “SYSTEM.ADDSTUDENTS”, line 10的信息就是我們期待的信息,提示出在這個存儲過程的第10行執行出現問題,而實際可以使用dbms_utility.format_error_backtrace結合exception給出更為清晰地方式,比如:

oracle@e871d42341c0:~$ cat /tmp/addstudent.sql 
create or replace PROCEDURE addstudents
IS
student_count number;
BEGIN
delete from student;
select count(*) into student_count from student;
dbms_output.put('sql set count before :');
dbms_output.put_line(student_count);
insert into student values (1001, 'liumiaocn');
insert into student values (1001, 'liumiao');
insert into student values (1003, 'michael');
select count(*) into student_count from student;
dbms_output.put('sql set count after :');
dbms_output.put_line(student_count);
exception
when others then
dbms_output.put('exception happend with line info : ');
dbms_output.put_line(dbms_utility.format_error_backtrace);
END;
/
exec addstudents();
oracle@e871d42341c0:~$

執行結果確認:

oracle@e871d42341c0:~$ sqlplus system/liumiao123 EOF
set serveroutput on;
@/tmp/addstudent.sql 
EOF
SQL*Plus: Release 11.2.0.2.0 Production on Mon Oct 22 04:49:27 2018
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
SQL> SQL> 
Procedure created.
sql set count before :0
exception happend with line info : ORA-06512: at "SYSTEM.ADDSTUDENTS", line 10
PL/SQL procedure successfully completed.
SQL> Disconnected from Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production
oracle@e871d42341c0:~$ 

這樣則可以看出能夠比較清晰地進行錯誤的定位了,但是由于功能受限,所以實際使用場景仍然較為有限,但是定位存儲過程的信息則可以使用dbms_utility.format_error_backtrace等進行確認。

小結

多行sql執行定位可以考慮拆成單行來確認,而存儲過程則可結合format_error_backtrace等進行確認以提供問題出現的所在行號。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接

您可能感興趣的文章:
  • Oracle 11g收集多列統計信息詳解
  • Oracle cloud control 12c的啟動、關閉及獲取安裝信息的方法
  • Oracle 查詢表信息獲取表字段及字段注釋
  • oracle獲取當前用戶表、字段等詳細信息SQL
  • Oracle 11g自動診斷信息庫(Automatic Diagnostic Repository,ADR)概述
  • ORACLE查看當前賬號的相關信息

標簽:焦作 滁州 遼源 涼山 南充 郴州 合肥 許昌

巨人網絡通訊聲明:本文標題《Oracle查詢sql錯誤信息的控制和定位》,本文關鍵詞  Oracle,查詢,sql,錯誤,信息,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Oracle查詢sql錯誤信息的控制和定位》相關的同類信息!
  • 本頁收集關于Oracle查詢sql錯誤信息的控制和定位的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美激情一区二区三区四区| 99免费精品视频| 欧美亚洲国产一区在线观看网站| 91成人在线精品| 精品免费日韩av| 中文字幕一区二区三区av | 18欧美乱大交hd1984| 日本中文字幕一区| 99久久伊人久久99| 久久美女高清视频| 亚洲一二三四在线| 在线视频一区二区三区| 亚洲一区二区视频| 91麻豆国产香蕉久久精品| 制服丝袜日韩国产| 91福利在线免费观看| 国产精品美女视频| 成人av电影观看| 中文一区在线播放| 国产精品99久久久久久久女警 | 亚洲男女毛片无遮挡| 成人一区二区三区视频在线观看| 久久久欧美精品sm网站| 国产一区二区免费在线| 国产欧美一区二区三区鸳鸯浴| 国产夫妻精品视频| 欧美性猛交一区二区三区精品| 欧美视频一区在线| 亚洲成av人片在线| 91精品国产免费久久综合| 图片区日韩欧美亚洲| 在线观看国产一区二区| 国产精品视频一二三| 国产一区在线不卡| 国产亚洲va综合人人澡精品 | 色综合色综合色综合色综合色综合 | 秋霞av亚洲一区二区三| 成人动漫在线一区| 国产精品拍天天在线| 成人av影院在线| 亚洲日本电影在线| 日本国产一区二区| 天天综合网天天综合色| 7777精品伊人久久久大香线蕉的| 日韩福利视频网| 国产亚洲va综合人人澡精品| 在线影视一区二区三区| 精品盗摄一区二区三区| 亚洲一区在线视频观看| 欧美在线视频不卡| 日韩中文字幕不卡| 欧美一区二区在线不卡| 久草中文综合在线| 国产精品久久久久一区 | 国产精品看片你懂得| 成人中文字幕电影| 亚洲国产wwwccc36天堂| 欧美一区二区三区四区高清| 国产99精品在线观看| 国产精品美女久久久久久久久| 国产精品一卡二卡在线观看| 中文字幕视频一区二区三区久| 色先锋aa成人| 亚洲一区二区三区在线看| 久久久久亚洲蜜桃| 粉嫩高潮美女一区二区三区| 国产精品污www在线观看| 欧美日韩国产123区| 国产最新精品免费| 亚洲国产sm捆绑调教视频| 欧美国产精品v| 精品视频在线免费观看| 岛国精品在线观看| 日韩影院免费视频| 国产亚洲综合性久久久影院| 91福利在线导航| 国产成人综合网站| 亚洲午夜电影在线| 国产精品久久久久久久岛一牛影视 | 在线观看一区二区视频| 国产一区视频导航| 婷婷成人综合网| 欧美国产精品久久| 欧美一级国产精品| 欧美日韩一级片在线观看| 99re成人精品视频| 成人av在线资源网| 粉嫩蜜臀av国产精品网站| 国产一区二区女| 国产自产v一区二区三区c| 午夜精品福利一区二区三区蜜桃| 中文字幕一区二区不卡| 国产色婷婷亚洲99精品小说| 欧美va亚洲va国产综合| 日韩欧美综合一区| 欧美一区二区三区白人| 这里只有精品免费| 欧美日韩国产bt| 欧美日韩久久一区| 色综合夜色一区| 91丨九色丨蝌蚪富婆spa| 成人av电影在线网| av中文字幕一区| 国产成人高清在线| 国产成人一级电影| 国产激情视频一区二区三区欧美| 精品一区二区日韩| 久久狠狠亚洲综合| 蜜桃av噜噜一区二区三区小说| 午夜精品视频一区| 国产欧美日韩综合精品一区二区| 欧美亚洲免费在线一区| 国产精品一区二区免费不卡 | 国产精品二三区| 国产精品伦理一区二区| 国产精品视频免费看| 亚洲欧美视频在线观看视频| 亚洲免费在线观看| 亚洲一区二区三区精品在线| 五月天中文字幕一区二区| 午夜a成v人精品| 久久精品国产亚洲aⅴ| 国产一区二区免费视频| 99久久综合国产精品| 91成人看片片| 91麻豆精品国产91久久久久| 日韩一区二区免费高清| 精品国产精品网麻豆系列 | 日韩精品一区二区三区在线播放| 日韩欧美视频在线| 国产亚洲人成网站| 中文字幕一区av| 首页综合国产亚洲丝袜| 激情图片小说一区| a亚洲天堂av| 欧美精品18+| 久久免费午夜影院| 亚洲色图视频免费播放| 亚洲一区成人在线| 日韩 欧美一区二区三区| 国产精品一二三区| 91黄色小视频| 日韩免费看网站| 中文字幕一区二区视频| 五月天亚洲精品| 国产成人av电影在线观看| 一本大道久久a久久综合婷婷| 在线播放日韩导航| 国产日韩欧美a| 亚洲超碰精品一区二区| 国产精品一线二线三线精华| 色综合久久中文综合久久97| 日韩欧美在线网站| 中文字幕亚洲在| 免费观看久久久4p| 91在线精品一区二区| 日韩欧美中文字幕公布| 亚洲欧美乱综合| 黑人巨大精品欧美一区| 欧美午夜影院一区| 国产精品午夜电影| 国内成人自拍视频| 欧美伊人久久大香线蕉综合69| 精品国产sm最大网站免费看| 亚洲精品国产视频| 国产成人精品影视| 欧美久久久久久久久| 中文字幕一区日韩精品欧美| 久久99精品久久久久久动态图 | 亚洲在线免费播放| 国产福利精品一区| 日韩一区二区三区三四区视频在线观看| 国产精品久久福利| 精品一区二区免费视频| 欧美精品一二三| 一区二区不卡在线播放| 懂色av一区二区三区蜜臀| 日韩精品一区二区三区在线播放| 性做久久久久久久免费看| 91丨porny丨蝌蚪视频| 国产日产欧美精品一区二区三区| 日本美女一区二区| 欧美日韩在线精品一区二区三区激情| 国产色综合久久| 国产麻豆欧美日韩一区| 日韩免费高清av| 偷偷要91色婷婷| 欧美日韩免费观看一区三区| 伊人性伊人情综合网| 99这里只有久久精品视频| 欧美激情综合网| 国产成人综合亚洲91猫咪| 久久久综合视频| 狠狠色丁香久久婷婷综合_中| 欧美老肥妇做.爰bbww| 亚洲午夜精品17c| 欧美精品777| 琪琪一区二区三区| 日韩欧美一级二级| 欧美aⅴ一区二区三区视频|