设为首页 收藏本站
查看: 463|回复: 0

[经验分享] ORACLE使用中的常见、实用的问题

[复制链接]

尚未签到

发表于 2016-7-27 10:59:13 | 显示全部楼层 |阅读模式
ORACLE使用中的常见、实用的问题
摘要:这是原来用ORACLE的过程中记录下的一些问题,现在翻出来看看,还比较实用,如果以后再次遇到这样的问题的时候,就不用东找西找资料了。
里面包括字段同步问题,单引号问题, EXECUTE IMMEDIATE的使用問題,replace使用問題,數據庫中字段為字符型時生成SQL語句的問題

1、同步表记录问题
有两张表t1,t2,有一个相同的字段,passwd,我想在更新t1表的passwd字段时同时更新t2的passwd字段,让他们保存一致,同样,在更新t2的passwd的时候同时更新t1的passwd.我分别做了两个触发器.单独对于某张表是可以的.但是同时启用两个触发器就会产生变异.
我想也对.这样不就是死循环了吗?请问怎样实现这样的功能.让两个字段保持一致。
解決:没用解决
2單引號問題:
這條語句select * from prd_flow_bak where cno='FT0302';可以工作正常。
這條語句select * from prd_flow_bak where cno=FT0302;工作不正常。
但是我的過程中又需要動態生成SQL語句,如
sql1:='select * from prd_flow_bak where cno='||thcur.cno;只能得到工作不正常的語句。
注:thcur.cno為用cursor取得的字段名。
這里我試了是不能夠這么寫的:
sql1:='select * from prd_flow_bak where cno=''||thcur.cno||''';
它不像在JAVA程序中,在JAVA程序中就好辦,因為它是以雙引號為包含。
請問這里怎么寫才能夠得到上面可以正常工作的語句

解決:
sql1:='select * from prd_flow_bak where cno='||''''||thcur.cno||'''';

3、EXECUTE IMMEDIATE的使用問題
這是一條根據條件動態生成的SQL語句(無錯):
insertSQL:='insert into Customer2To3_M values(';
insertSQL:=insertSQL||''''||currentCNO||''''||',';
insertSQL:=insertSQL||to_date(to_char(dateIntBegin),'YYYYMMDD')||',';
insertSQL:=insertSQL||''''||''''||','||avgSalaryOfThisDay;
insertSQL:=insertSQL||','||''''||to_char(to_date(to_char(dateIntBegin),'YYYYMMDD'),'Day')||''''||')';
使用下面的這樣執行會出錯:
execute immediate insertSQL;
報錯:
ORA-00917: missing comma
但是我檢測絕對沒有少。不知道是什么地方出錯,還是DML語句不可以這樣使用。但是從不少資料看都可以這樣使用的,后來實在沒法,到CSDN上一搜,在這里找到一篇文章: http://blog.csdn.net/zhujjcn/archive/2005/02/04/280749.aspx
有心得,就用下面這種方式把問題解決了:
execute immediate 'insert into Customer2To3_M values(:1,:2,:3,:4,:5)'
using currentCNO,to_date(to_char(dateInt),'YYYYMMDD'),totalORDNO,avgSalaryOfThisDay,to_char(to_date(to_char(dateInt),'YYYYMMDD'),'Day');
注: 根據我的理解,其中的數字表示的是字段的該中的位置。

4、replace使用問題
我在匿名塊中這樣使用:
replace(insertSQL,'kkk','ttt');
可是去給我報以這樣的錯誤
8:51:44PLS-00221: 'REPLACE' is not a procedure or is undefined
明明是有這個函數為什么會出現這種情況呢,真的讓我頭痛。
我試了一下這樣:
insertSQL:=replace(insertSQL,'kkk','ttt');
正常運行,呵呵。

5、數據庫中字段為字符型時生成SQL語句的問題
在任何一種高級語言中,如果要操作表中字段是字符型的,那么就一定要在該字兩邊加上單引號,這一點也是我們很多人都會去注意的。所以,給了我一種心理,就是在所有的操作字符類型的時候都要加上單引號。
但是在ORACLE的游標中就不用(肯定還有其它的情況,我沒有遇上)
如下面這個復雜的游標:
cursor c1(startDateOfThisMonth in varchar2,endDateOfThisMonth in varchar2,nowDateOfThisMonth in varchar2,paraCNO in varchar2)
is
select ordno,pro_fr,pro_to,QTY,CNO from prd_flow_bak
where pro_fr>=to_date(startDateOfThisMonth,'YYYYMMDD')
and pro_to<to_date(endDateOfThisMonth,'YYYYMMDD')
and cno=paraCNO --就是這里,在表中為字符型
and (to_date(nowDateOfThisMonth,'YYYYMMDD') between pro_fr and pro_to);
剛開始的時候,我把這里寫成這樣:
and cno=''''||paraCNO||''''
讓我可忙活了半天,我運行的時候,不是這樣報錯,他出現在錯誤去在該游標的上面几行,說一個定義錯誤,但是這明明是正確的。沒法,我只得新建一個文件,一行一行的去試,才把這個問題找出來。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-250201-1-1.html 上篇帖子: Oracle SQL*Loader 使用指南【转】 下篇帖子: Oracle中"HINT"的30个用法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表