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

[经验分享] 关于oracle的一点备忘

[复制链接]

尚未签到

发表于 2018-9-6 11:33:26 | 显示全部楼层 |阅读模式
  数据库无法回避的就是处理数据
  情景:发票信息,很多公司员工在进行交易的时候,填写的发票信息都是一样的,所以公司员工往往想调用统一的发票信息,公司会计登录系统可以填写通用发票信息,为了生成订单简单,发票需要和员工号码绑定,所以发票的表里想要复制一份员工号为会计的发票信息,改动其中的员工号,发票id,创建时间,其余不变
  不知道大家弄懂应用情境没,叙述能力有限。
  解决:可以使用select into,但是感觉不方便和灵活。所以考略利用右边和存储过程,因为没有返回值,就不写函数了
  上代码:
create or replace procedure myprocd(  
    uid in varchar2
  
)
  
AS
  
    receipt_autoid number;
  
BEGIN
  
    select SEQ_CHEM_DICT_RECEIPT.NEXTVAL into receipt_autoid from dual;
  
    for rs in (select * from CHEM_DICT_RECEIPT where user_id='0')
  
    loop
  
        rs.user_id:=uid;
  
        rs.id:=receipt_autoid;
  
        rs.receipt_id:='RE0215'||receipt_autoid;
  
        rs.created_time:=sysdate;
  
        insert into chem_dict_receipt values rs;
  
    end loop;
  
END myprocd;
  
execute myprocd('002');
  提醒:我实在是没搞清楚序列如何在循环中增加,所以我更改了策略,我让游标只能读取一次,也就是不再循环,所以更改如下
CREATE OR REPLACE procedure SIT_HXPGL.myproce(  
    uid_re in varchar2,
  
    type_re in varchar2
  
)AS
  
    receipt_autoid number(12);
  
BEGIN
  
    select SEQ_CHEM_DICT_RECEIPT.NEXTVAL into receipt_autoid from dual;
  
    for rs in (select * from CHEM_DICT_RECEIPT where user_id='0' and receipt_type=type_re)
  
    loop
  
        rs.user_id:=uid_re;
  
        rs.id:=receipt_autoid;
  
        rs.receipt_id:='RE0215'||receipt_autoid;
  
        rs.created_time:=sysdate;
  
        insert into CHEM_DICT_RECEIPT values rs;
  

  
    end loop;
  
END myproce;
  
/
  无奈:代码里没有办法标红。我新加了一个变量
type_re  这样我的游标只能每次读取一组数据。
  最后加一句,关于执行存储过程,好像是call和execute都可以,推荐使用call
  小思路:好像可以吧获取自增序列放在自定义函数,然后调用,可能不会有问题
  关于函数和存储过程或者游标,这里有个链接很好,可以参考下
  http://wen866595.iteye.com/blog/1733887       程序点滴
  其中有个小问题,我实在实践中发现的,但是还没看oracle的官方文档。
  问题:存储过程的结束END;
  解决:END myproc;
  解释:应该是要加上存储过程的名字



运维网声明 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.iyunv.com/thread-564011-1-1.html 上篇帖子: 如何创建只读权限oracle账户 下篇帖子: oracle decode函数和 sign函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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