我的编程空间,编程开发者的网络收藏夹
学习永远不晚

关于oracle的一点备忘

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

关于oracle的一点备忘

数据库无法回避的就是处理数据


情景:发票信息,很多公司员工在进行交易的时候,填写的发票信息都是一样的,所以公司员工往往想调用统一的发票信息,公司会计登录系统可以填写通用发票信息,为了生成订单简单,发票需要和员工号码绑定,所以发票的表里想要复制一份员工号为会计的发票信息,改动其中的员工号,发票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;

解释:应该是要加上存储过程的名字

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

关于oracle的一点备忘

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

关于备考11月软考,给考生的5点建议!

报名成功后,就要进入备考阶段了,有些考生可能早就开始学习了,部分考生还处在迷茫的阶段,不知道该怎么学。为此,小编给大家5点建议。
关于备考11月软考,给考生的5点建议!
2024-09-06

关于无线上网的一些基础知识点

  无线上网是指使用无线连接的互联网登陆方式。它使用无线电波作为数据传送的媒介。速度和传送距离虽然没有有线线路上网优秀,但它以移动便捷为杀手锏,深受广大商务人士喜爱。现在就跟着小编共同来学习一下:关于无线上网的一些基础知识点。  一、前提介绍  非常的朋友还是在使用无线网络(也有人称之为WiFi或者是802.11网络)
关于无线上网的一些基础知识点
2024-04-18

【杂烩】Latex中的一些技巧备忘录

1. subfigure 和 minipage 环境的运用 首先是多张图组合到一起,左侧和下方备注列标题和行标题。 使用的时候需要的包: minipage不需要 \usepackage{subfigure}\usepackage{g
2023-08-21

关于flashbackup-windows备份的还原

还原FlashBackup-Windows备份可以按照以下步骤进行操作:1. 打开FlashBackup-Windows备份软件。通常,还原选项应该在主界面或菜单中。2. 在还原选项中,选择您要还原的备份文件。这些备份文件通常以日期和时间作
2023-08-08

关于网络互连以及互联网的知识点(一)

  网络互连是指将不同的网络连接起来,以构成更大规模的网络系统,实现网络间的数据通信、资源共享和协同工作。今天小编为大家带来的一篇教程,那就是:介绍网络互连以及互联网的知识点。  大家知道什么叫做互联网码?其实简单来说,将多个网络互相连接组成范围更大的网络将其称之为互联网(internet)。因为各种各样网络使用的技术
关于网络互连以及互联网的知识点(一)
2024-04-17

Android 关于RemoteViews的理解(一)

前言 RemoteViews从字面上理解是远程View,这个理解可能有点抽象,我们听过远程服务,但是远程View听说过的Android开发者应该很少,其实远程View和远程Service是一样的。谷歌设计这个View的主要目的是为了跨进程更
2022-06-06

聊一聊关于MySQL的count(*)

2. count(*)的实现方式据说,MyISAM 引擎把一个表的总行数存在了磁盘上,因此执行 count(*) 的时候会直接返回这个数,效率很高。而我们的mysql一般都是用Innodb的引擎,Innodb是怎么实现count操作的呢?InnoDB 引擎就比
聊一聊关于MySQL的count(*)
2020-12-23

关于cron表达式每天整点执行一次的问题

这篇文章主要介绍了关于cron表达式每天整点执行一次的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-23

与oracle 有关的那点事

常用操作1.查看创建表参数提取完整的DDL:SELECT DBMS_METADATA.GET_DDL("TABLE","table_name") FROM DUAL;2.指定返回记录数select XXX from XXX where rownumn (n>
与oracle 有关的那点事
2018-11-19

编程热搜

目录