oracle存储过程中如何写循环?

我现在需要一个存储过程,这个存过里只存放删除 XXXX_TABLE表 的分区语句,只保留每个月最后一天的分区,我该怎么写啊

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
oracle 存储过程如何做双循环

如图1所示,同一个MATERIEL_ID有多个SUPPLIER_ID的多个价格变动记录(OLD_PRICE/NEW_PRICE)(根据日期ORDER_DATE)。为了举例,挑选了SUPPLIER_ID=10101058的价格记录,需要根据最早的价格生成时间2014/5/7,每12个月为一个周期,将价格变动情况匹配到相应周期中去。上一个周期的NEW_PRICE,默认为下个周期开始的OLD_PRICE。若某个周期无对应价格变动记录,默认取上个周期的NEW_PRICE为该周期的价格(如2017/5/7~2018/5/7这个周期)。 目前我已经将需要的数据做成了两个视图,图二为实际的价格变动记录。图三为最终需要的结构,需要填充价格区间。考虑了下需要用存储过程做双循环来实现,该怎么做? ![图一](https://img-ask.csdn.net/upload/202004/22/1587544550_597516.png) ![图二](https://img-ask.csdn.net/upload/202004/22/1587544626_653880.png) ![图三](https://img-ask.csdn.net/upload/202004/22/1587544637_989544.png)

ORACLE 存储过程 关于游标循环从一个表COPY到另一个表插入问题

``` create or replace procedure insertspzl as is_tb number(2):=1;-- 1 已经同步 2 未同步 3 修改状态 spbh VARCHAR2(255); sccj VARCHAR2(255); sccjpd VARCHAR2(255); --判断生产厂家是否存在 变量 jxname VARCHAR2(255); jxnamepd VARCHAR2(255); spfl VARCHAR2(255); jyfw VARCHAR2(255); cursor cur is select trim(商品编号) spbh,trim(生产厂商) sccj,trim(剂型) jx,trim(商品类型) spfl,trim(商品类型) jyfw from 商品资料@TEST; begin -- 增加资料处理字段 -- alter table zl_spzlb add (bzdw VARCHAR2(255)); -- alter table zl_spzlb add (sccj VARCHAR2(255)); -- alter table zl_spzlb add (jx VARCHAR2(255)); -- alter table zl_spzlb add (spfl VARCHAR2(255)); -- For 循环逐条插入记录 for temp in cur loop spbh :=temp.spbh; sccj :=temp.sccj; jxname :=temp.jx; spfl :=temp.spfl; jyfw :=temp.jyfw; select trim(是否同步) into is_tb from 商品资料@TEST where trim(商品编号)=spbh ; Dbms_Output.put_line('--打印is_tb--'||is_tb||'--编号--'||spbh); -- If 判断单条条件处理 if is_tb =1 then Dbms_Output.put_line('--发现未同步商品--'||spbh); Dbms_Output.put_line('--厂家--'||sccj); Dbms_Output.put_line('开始插入数据'); --插入商品资料 insert into zl_spzlb (resid,bh,spbh,name,sptym,slv,pzwh,spcd,cctj,is_zdyh,is_ty,bzdw,spgg,sccj,jx,spfl) select seq_acl_res_resid.nextval,trim(商品编号),trim(商品编号),trim(商品名称),trim(通用名), trim(税率),trim(批准文号),trim(产地), decode(trim(储存条件),'密封,置阴凉处','阴凉、暗凉(密闭,遮光)','密封','阴凉、暗凉(密闭,遮光)', '密封,置阴凉处(不超过20°)','阴凉、暗凉(密闭,遮光)','遮光','阴凉、暗凉(密闭,遮光)','阴凉', '阴凉、暗凉(密闭,遮光)','常温','常温(干燥0℃-30℃)','冷藏','冷藏(2℃-10℃)','其他'), decode(trim(养护措施),'普通养护',2,'重点养护',1),decode(trim(是否停用),'否',2,'是',1),trim(单位), trim(规格),trim(生产厂商),trim(剂型), trim(商品类型) from 商品资料@TEST where trim(商品编号)=spbh; --插入包装资料 Dbms_Output.put_line('--商品--'||spbh); insert into zl_bzggzlb(bzid,spid,jlgg,is_hd,name) select seq_zl_bzggzlb_bzid.nextval,a.resid,1,1,a.bzdw from zl_spzlb a where a.spbh=spbh; --更新 update zl_spzlb a set (a.lsbzid,a.pfbzid)=(Select b.bzid,b.bzid From zl_bzggzlb b Where a.resid=b.spid and a.spbh=spbh) where a.spbh =spbh; end loop; commit; --for 循坏结束 end insertspzl; ``` 游标循环不允许再 遍历游标的时候 有insert的操作,并且执行了commit 但是如果commit 放在循化外面 会在获取 商品资料@TEST 第二行记录插入时候 --插入包装资料 在这一块把第一次生产的数据带出来重复插入 导致 --更新 这一块没办法进行 返回多行 如何去隔离上一次循环 不影响下一次并且最后提交都提交 求大大们指教

ORACLE 存储过程 循环更新不成功

下面这个更新是在存储过程的for循环里的。 发现一个问题是,如果对同一条数据进行更新时,有时会更新不上。 麻烦各位帮看一下可能是什么原因 ``` UPDATE CCTR01ST SET ACCUMPT = ACCUMPT + tbl_list.ADDPT, REMAINPT = REMAINPT + tbl_list.ADDPT, SENDFL = 'Y', FDSENDFL = 'Y', UPDID='job_system', UPDDATE=SYSDATE WHERE CSTMNO = tbl_list.CSTMNO; ```

Oracle存储过程中的字符串比较

我在oracle存储过程中使用了一句: If i_flag is not null and i_flag <> '' then --处理过程 End if; i_flag是个传入参数,但是不管传入什么值,都进不到if中去,求大神指导!!!

Oracle存储过程 截取字符串循环执行动作 急急急急!

create or replace procedure PROC_UPDATENEWSKW(newsid in number, kw in varchar2) is i number:=0; begin /** 1.查询标签表(jc_content_tag)是否有相同tag_name的标签,如果有则直接将此条记录的tag_id与newsid 插入jc_contenttag(新闻标签关联表)表 */ select count(*) into i from jc_content_tag where tag_name =kw; if i>0 then insert into jc_contenttag (tag_id,content_id,priority) values ((select tag_id from jc_content_tag where tag_name = kw and rownum=1),newsid,1); else /** 2.将kw插入标签表 tag_id 序列自增 */ insert into jc_content_tag (tag_id,tag_name) values (S_JC_CONTENT_TAG.NEXTVAL,kw); /** 3.将内容标签中不存在标签的记录 tag_id 更新。 */ insert into jc_contenttag (tag_id,content_id,priority) values ((select tag_id from jc_content_tag where tag_name = kw and rownum=1),newsid,1); end if; commit; end PROC_UPDATENEWSKW; 这个存储过程只能应对带个字符串的情况,假如传进来的kw参数 格式为 1,2,a,c,呵,呵 我首先需要截取这些字符串 然后 for 或者loop 来循环 执行以上的操作那么问题来了,存储过程怎么截取字符串并且执行循环操作,十万火急!

oracle将sql语句写成存储过程

想要把原sql语句写成存储过程,这样以后就直接调用存储过程来执行这一段语句了 求大神帮忙看看我写的是否正确,谢谢 原sql语句: TRUNCATE TABLE tab1; INSERT tab1 SELECT s.storecode,s.category,nvl(curr.vol,0)/s.avg_vol - 1 AS growth FROM ( SELECT periodcode,storecode,CATEGORY,vol FROM tab2 WHERE periodcode = &periodcode) curr, (SELECT storecode,category,AVG(vol) avg_vol FROM tab2 GROUP BY storecode,CATEGORY HAVING AVG(vol) > 0) s WHERE curr.storecode(+) = aveg.storecode AND curr.category(+) = s.category 打包为存储过程: create or replace procedure p_tab1 AS BEGIN TRUNCATE TABLE tab1; INSERT tab1 SELECT s.storecode,s.category,nvl(curr.vol,0)/s.avg_vol - 1 AS growth FROM ( SELECT periodcode,storecode,CATEGORY,vol FROM tab2 WHERE periodcode = &periodcode) curr, (SELECT storecode,category,AVG(vol) avg_vol FROM tab2 GROUP BY storecode,CATEGORY HAVING AVG(vol) > 0) s WHERE curr.storecode(+) = aveg.storecode AND curr.category(+) = s.category COMMIT; END;

oracle在存储过程中执行update语句

在存储过程中经过加工对表执行update语句,但表的数据太大了,2百多万数据的表我就要执行1个多小时,,,8千多万数据的表要怎么办啊?

ORACLE存储过程遇到不合规数据跳过记录到日志然后继续插入合规数据

请大神写一个详细示例。要不然我看不懂,急急急 急。有没有 oracle前辈 花点时间,有偿有偿指导一下我。 请教一个存储过程问题 场景模拟: A表插入B表 A表 字段1VARCHAR2(40) 字段2VARCHAR2(40) 字段3VARCHAR2(40) A A A B B B C C C DDDDD DDDD DDD B表 字段1VARCHAR2(1) 字段2 VARCHAR2(1) 字段3VARCHAR2(1) 进入目标表,目标表字符串长度不同 现在有四条数据要插入进去,其中一条字符长度超长了。正常insert会存储过程报错,四条都插不进去,我想继续执行把其他三条正常插入,报错那一条记录的到日志

oracle优化存储过程,使其提高效率

说明:优化这个存储过程,T_text 数据为100多条;T_text_standard 200万条数据,现在这个存储过程严重影响效率,请大神帮我优化一下,或这用普通sql写出来 T_text 表结构 ,ID,xm,ygid ,zh , lx ,time,status ; T_text_standard 表结构 xm,ygid ,zh ; create or replace procedure PROC_text (inputterm in varchar2,return_value out varchar2) is cursor bm_cursor is select * from T_text where time=inputterm; datarow bm_cursor%rowtype;--数据每行 data_count number; --数据数量 -- inputterm 日期 --status 状态 0删除 1.正常 --ygid 员工号 -- lx 类型 01:开户 02:变更 03:销户 -- zh 账户 --T_text_standard 标准表 --T_text 基础表 begin return_value:='yes'; --删除不是当前日期的数据 for datarow in bm_cursor loop update T_text t set t.status='0' where ygid=datarow.ygid and zh=datarow.zh and time<>inputterm; commit; --查询标准库 --循环查询标准库信息 execute immediate'select count(1) from T_text_standard where ygid= '''||datarow.ygid||'''and zh='''||datarow.zh ||'''' into data_count; --如果查询数量>0 但不销户,修改类型为变更 if data_count >0 then execute immediate 'update T_text set lx=''02'' where ygid='''||datarow.ygid||'''and zh='''||datarow.zh||'''and lx<>''03'''; commit; else --如果查询数量其他 但不销户,修改类型为开户, execute immediate 'update T_text set lx=''01'' where ygid='''||datarow.ygid||'''and zh='''||datarow.zh||'''and lx<>''03'''; commit; --如果标准库中不存销户信息,则复制这条信息为开户信息 if datarow.lx='03' then execute immediate' insert into T_text select ''012'', xm, ygid,lx,zh,status ,time from T_text where khyhdm='''||datarow.id||''''; commit; end if; end if; end loop; end PROC_text;

oracle数据库存储过程 截取数据

oracle数据库存储过程问题: 传入一个字符串(字符串格式如:“辣椒_食品,西红柿_食品,板鞋_服饰,植物油_食品,领带_食品,……”) 现在我想根据“,”来截断字符串存储到数组(其他变量也行)。然后就可以得到这样的数组string[] arr={“辣椒_食品”,“西红柿_食品”,……} 然后循环遍历这个数组,循环每条数据的时候再根据“_”来分割数据,分割完成后存储在两个变量中,在根据变量来执行update语句。 目的就是要把传入的字符串根据“,”分割,然后在根据“_”分割,分割后分别执行update语句,如:update 表 set 字段1=当前时间 where 字段2=根据“_”分割的前面一部分 and 字段2=根据“_”分割的后面一部分

如何用oracle的存储过程实现查询一张表数据,放到另一张表中?

如table1: name time :2012-12-12 total table2:name timesteamp :12/12月/2012 这里我要将表2中的某个名字和日期和他们(名字日期一致)的总条数,查出来放到表1中, 如何实现?

关于oracle存储过程游标循环的问题

create or replace procedure pro_loop(userid in varchar2) is departid number(4); begin begin declare cursor list is select departid from departmment ; rs list%rowtype; begin for rs in list loop dbms_output.put_line(rs.departid); end loop; end; end; /************************************************以上是存储过程******************************************/ PROCEDURE COMPANY.PRO_LOOP编译错误 错误:PLS-00103: Encountered the symbol "end-of-file" when expecting one of the following: begin case declare end exception exit for goto if loop mod null pragma raise return select update while with <an identifier> <a double-quoted delimited-identifier> <a bind variable> << close current delete fetch lock insert open rollback savepoint set sql execute commit forall merge pipe /*********************************************************************************************************/ 烦请各位高手指正一二

ORACLE存储过程日期循环插入不知道错误的地方在哪。求解

create or replace procedure test_date is v_start date; v_end date; v_endday date; v1 date;--日期 v2 date;--年月 v3 date;--月份 v4 date;--季度 v5 date;--一年中的第几周 v6 date;--星期几 v7 date;--是否周六周日 v8 date;--日期的上个月 v9 date;--本月最后一天 i number; k number; begin v_start:=to_date('20160401','yyyymmdd'); v_end:=to_date('20160601','yyyymmdd'); k:=v_end-v_start; for i in 0..k loop v1:=v_start date+to_date(i); v2:=to_char(v1,'yyyy-mm') ; v3:=to_char(v1,'mm'); v4:=to_char(v1,'q'); v5:=to_char(v1,'ww'); v6:=to_char(v1,'dy'); v7:=decode(v1-1,1,0,2,0,3,0,4,0,5,0,6,1,7,1); v8:=to_char(add_months(v6,-1),'yyyy-mm'); v9:=last_day(v1); insert into test_date1 values(v1,v2,v3,v4,v5,v6,v7,v8,v9); end loop end test_date; ``` ``` 需要实现的功能建一个这样的表 create table test_date ( v1 varchar2(40), v2 varchar2(40), v3 varchar2(40), v4 varchar2(40), v5 varchar2(40), v6 varchar2(40), v7 varchar2(40), v8 varchar2(40), v9 varchar2(40) ); 要求写一个存储过程 往这个测试表中插入数据 从2007年1月1日到2008年1月17日 循环插入 V1 V2 V3 V4(季度) V5(一年中的第几周) V6(星期几) V7(是否周六日) V8(上一月) V9(本月最后一天) 2007年01月01日 200701 01 1 1 1 0 200612 20070131 2007年01月02日 200701 01 1 1 2 0 200612 20070131 2007年01月03日 200701 01 1 1 3 0 200612 20070131 2007年01月04日 200701 01 1 1 4 0 200612 20070131 2007年01月05日 200701 01 1 1 5 0 200612 20070131 2007年01月06日 200701 01 1 1 6 1 200612 20070131 2007年01月07日 200701 01 1 1 7 1 200612 20070131 2007年01月08日 200701 01 1 2 1 0 200612 20070131

c#.net 调用oracle存储过程,不能正常回滚

本人是个小菜,刚接触.net不久,使用事务不熟练,导致回滚失败。下面是代码: enter code here using (OracleConnection conn = new OracleConnection(strConn)) { if (conn.State != ConnectionState.Open) { conn.Open(); } OracleCommand cmd = conn.CreateCommand(); OracleTransaction ot = conn.BeginTransaction(IsolationLevel.ReadCommitted); cmd.Connection = conn; cmd.Transaction = ot; //cmd.Transaction = ot; //OracleTransaction ot = conn.BeginTransaction(); try { foreach (XmlNode node in itemNodes) { rcptGroupId = Convert.ToString(node.SelectSingleNode("RcptGroupID").InnerText); amt = node.SelectSingleNode("Price").InnerText; OracleParameter[] pm = new OracleParameter[14]; pm[0] = new OracleParameter("cardno", OracleType.VarChar, 20); pm[0].Direction = ParameterDirection.Input; pm[0].Value = cardNo; pm[1] = new OracleParameter("rcptgroupid", OracleType.VarChar, 100); pm[1].Direction = ParameterDirection.Input; pm[1].Value = rcptGroupId; pm[2] = new OracleParameter("amt", OracleType.Number); pm[2].Direction = ParameterDirection.Input; pm[2].Value = float.Parse(amt); pm[3] = new OracleParameter("secrityno", OracleType.VarChar, 32); pm[3].Direction = ParameterDirection.Input; pm[3].Value = secrityNo; pm[4] = new OracleParameter("cardserno", OracleType.VarChar, 32); pm[4].Direction = ParameterDirection.Input; pm[4].Value = cardSerNo; pm[5] = new OracleParameter("userid", OracleType.VarChar, 4); pm[5].Direction = ParameterDirection.Input; pm[5].Value = userID; pm[6] = new OracleParameter("rcptno", OracleType.VarChar, 20); pm[6].Direction = ParameterDirection.Output; pm[7] = new OracleParameter("resultcode", OracleType.Int16); pm[7].Direction = ParameterDirection.Output; pm[8] = new OracleParameter("errormsg", OracleType.VarChar, 200); pm[8].Direction = ParameterDirection.Output; //add 2013.8.1 pm[9] = new OracleParameter("Bank", OracleType.VarChar, 20); pm[9].Direction = ParameterDirection.Input; pm[9].Value = bank; pm[10] = new OracleParameter("BankNo", OracleType.VarChar, 20); pm[10].Direction = ParameterDirection.Input; pm[10].Value = bankno; pm[11] = new OracleParameter("TransMoney", OracleType.VarChar, 10); pm[11].Direction = ParameterDirection.Input; pm[11].Value = decimal.Parse(TransMoney); pm[12] = new OracleParameter("CashTraceNo", OracleType.VarChar, 30); pm[12].Direction = ParameterDirection.Input; pm[12].Value = CashTraceNo; pm[13] = new OracleParameter("TerminalId", OracleType.VarChar, 16); pm[13].Direction = ParameterDirection.Input; pm[13].Value = TerminalId; cmd.CommandType = CommandType.StoredProcedure; cmd.CommandText = "pkg_autobillservice.proc_autoopbillcharge2"; cmd.Parameters.AddRange(pm); cmd.ExecuteNonQuery(); rcptNoList.Add(Convert.ToString(pm[6].Value)); } ot.Commit(); } catch (Exception ex) { ot.Rollback(); return string.Format(result, "1", ex.Message, "", rcptGroupId); } finally { cmd.Dispose(); ot.Dispose(); } } 调用存储过程,第一次错误了能回滚,再执行一次到cmd.ExecuteNonQuery()数据就已经提交了。 这样写在循环第二次的时候还会报错,错误为:System.Data.OracleClient.OracleExceptionMessage=ORA-06550: 第 1 行, 第 7 列: PLS-00703: 列表中具有指定参数的多个实例。 一天了还是没有法解决,求大家帮忙看下。

mybatis调用oracle存储过程报错

错误如下 ``` java.sql.SQLException: ORA-06550: 第 1 行, 第 7 列: PLS-00201: 必须声明标识符 'DOINENTITYDATA' ORA-06550: 第 1 行, 第 7 列: PL/SQL: Statement ignored ``` ``` -- 替换或创建存储过程 CREATE OR REPLACE PROCEDURE doInentityData as --声明游标 存储ODS的有效数据 CURSOR datas IS SELECT --身份证号 person.CertiCode IDNumber, --姓名 person.PersonName pname, --理赔编码 person.ClaimQueryNo ClaimQueryNo, --出险时间 regist.DamageDate ClaimTime, --涉案车牌号 endcase.LicenseNo CarNumber, --涉案公司 person.CompanyCode CompaniesInvolved, --地区代码 person.AreaCode AreaCode , --结案时间 endcase.LastEndCaseTime ClosedTime, --赔款总金额 endcase.SumPaid ClaimAmount, --保单号 statu.PolicyNo PolicyNo , --伤亡人员类型 person.MedicalType MedicalType, --险种 V3101开始的是商业险 CASE WHEN instr(person.ClaimQueryNo,'V3101',1,1) <> '0' THEN '2' ELSE '1' END Coverage --在四张临时表查询数据 FROM SIALPERSONTEMP person , SIALCLAIMSTATUSTEMP statu, SIALREGISTEMP regist, SIALENDCASETEMP endcase --表关系 WHERE person.USERCODE=statu.USERCODE AND statu.USERCODE=regist.USERCODE AND regist.USERCODE=endcase.USERCODE ; -- 查询出的一行数据 hang datas%rowtype; -- 身份信息主键id idcard SIDENTITY.IdentityID%type; -- 理赔信息信息是否存在,从而判断添加还是更新 flag number(10,2) ; BEGIN --打开游标 OPEN datas; --循环处理查询出的数据 LOOP FETCH datas INTO hang; Exit WHEN datas%notfound; --插入身份信息表,并返回主键 INSERT INTO SIDENTITY (IdentityID,IDNumber,IDType,DataSource,"NAME",CheckStatus,CancelStatus,NameStatus,ValidStatus) VALUES (INENTITY_NUM.NEXTVAL ,hang.IDNumber, '01', '1', hang.pname, '1', '0', '1', '1') returning IdentityID INTO idcard; -- 查询理赔信息存不存在,存才更新,不存在插入 SELECT count(1) INTO flag FROM SCLAIM WHERE IDENTITYID=idcard AND CLAIMSENCODING=hang.ClaimQueryNo; --判断理赔信息是否存在? IF flag>0 --更新理赔信息 THEN UPDATE SCLAIM SET ClaimTime=hang.ClaimTime , CarNumber=hang.CarNumber, CompaniesInvolved=hang.CompaniesInvolved , AreaCode=hang.AreaCode, ClosedTime=hang.ClosedTime, ClaimAmount=hang.ClaimAmount, PolicyNo =hang.PolicyNo, Coverage=hang.Coverage, MedicalType=hang.MedicalType,ModifyTime=sysdate,ValidStatus='1' WHERE IDENTITYID=idcard AND CLAIMSENCODING=hang.ClaimQueryNo; ELSE INSERT INTO SCLAIM (IdentityID,ClaimsEncoding,ClaimTime,CarNumber,CompaniesInvolved,AreaCode,ClosedTime ,ClaimAmount,PolicyNo,Coverage,MedicalType,StorageTime,ValidStatus) VALUES ( idcard, hang.ClaimQueryNo, hang.ClaimTime,hang.CarNumber, hang.CompaniesInvolved, hang.AreaCode, hang.ClosedTime, hang.ClaimAmount,hang.PolicyNo,hang.Coverage, hang.MedicalType, sysdate, '1' ); END IF; END LOOP; --将四张表的临时数据插入到正式表中 --INSERT INTO SIALREGIS (CLAIMQUERYNO,USERCODE,AREACODE,COMPANYCODE,DAMAGEDATE,VALIDSTATUS) SELECT CLAIMQUERYNO, USERCODE, AREACODE, COMPANYCODE, DAMAGEDATE, VALIDSTATUS FROM SIALREGISTEMP; --INSERT INTO SIALCLAIMSTATUS (CLAIMQUERYNO,USERCODE,AREACODE,COMPANYCODE,POLICYNO,VALIDSTATUS) SELECT CLAIMQUERYNO, USERCODE, AREACODE, COMPANYCODE, POLICYNO, VALIDSTATUS FROM SIALCLAIMSTATUSTEMP ; --INSERT INTO SIALENDCASE (CLAIMQUERYNO,USERCODE,AREACODE,COMPANYCODE,LICENSENO,LASTENDCASETIME,SUMPAID,VALIDSTATUS) SELECT CLAIMQUERYNO,USERCODE, AREACODE, COMPANYCODE, LICENSENO, LASTENDCASETIME, SUMPAID, VALIDSTATUS FROM SIALENDCASETEMP ; ---INSERT INTO SIALPERSON (CLAIMQUERYNO,USERCODE,AREACODE,SERIALNO,COMPANYCODE,PERSONNAME,CERTITYPE,CERTICODE,UNDERDEFLOSS,PERSONPROPERTY, MEDICALTYPE,VALIDSTATUS) --SELECT CLAIMQUERYNO,USERCODE,AREACODE,SERIALNO,COMPANYCODE,PERSONNAME, CERTITYPE,CERTICODE, UNDERDEFLOSS, PERSONPROPERTY, MEDICALTYPE, VALIDSTATUS FROM SIALPERSONTEMP ; --删除临时表的数据 --DELETE FROM SIALREGISTEMP; --DELETE FROM SIALCLAIMSTATUSTEMP; --DELETE FROM SIALENDCASETEMP; --DELETE FROM SIALPERSONTEMP; END; ``` ``` <update id="doInentityData" statementType="CALLABLE"> {call Inentity.DOINENTITYDATA()} </update> ```

求指导写一段存储过程如何通过循环实现

业务场景:假如A公司,甲客户分别发生了4笔业务,要求回款从后至前倒剪 ,更新基表数据。 例如: A 表 公司 客户 日期 应收金额 A 甲 0103 100 A 甲 0105 200 A 甲 0506 500 B表 公司 客户 收款金额 A 甲 200 通过存储过程实现 实现结果: 公司 客户 日期 应收金额 A 甲 0103 0 A 甲 0105 100 A 甲 0506 500

存储过程 使用for循环更新执行 报错 ORA-06550

create or replace procedure test is Cursor C_EMP is select * from CST_TW_RECORD where GRANT_STATE = '0' and CLEAN_STATE = '3' ; C_ROW C_EMP%ROWTYPE; --定义游标变量,该变量的类型为基于游标C_EMP的记录 begin --For 循环 FOR C_ROW IN C_EMP LOOP -- 更新清洗记录表 update CST_TW_RECORD set GRANT_STATE = 1,GRANT_FIRST_DATE=sysdate,GRANT_DATE=sysdate,SELLER_ID = 2012999991,GRANT_REMARK = 11 where CUST_ID=C_ROW.CUST_ID ; --更新客户表 update CST_CUSTOMER set APP_DATE = sysdate,PAST_DATE = sysdate,SELLER_ID = 2012999991,SELLER_DEPT_ID = 0001 where CUST_ID=C_ROW.CUST_ID ; --踢出客户 UPDATE CST_CUSTOMER_EXTEND SET PUB_STATE = 1 WHERE CUST_ID =C_ROW.CUST_ID ; end; end LOOP; end test; --执行存储过程 begin execute test ; end; ![图片说明](https://img-ask.csdn.net/upload/201709/08/1504853800_151544.png)

oracle存储过程使用游标的问题

create or replace procedure test3( templete_id in varchar2 ) as t_id_tmp varchar2(50); ty_id_tmp varchar2(50); cursor type_cur is select t1.id as type_id,t1.type_name from t_type t1,t_templete_link t2,t_templete t3 where t1.id = t2.type_id and t2.templete_id = t3.id and t3.id = templete_id; -- n number; begin select sys_guid() into t_id_tmp from dual; --复制模板信息 insert into t_templete select t_id_tmp as id, t.templete_name from t_templete t where t.id = templete_id; commit; dbms_output.put_line(templete_id); --复制类别信息 -- declare begin for type_rec in type_cur loop -- n:=n+1; -- dbms_output.put_line(1); select sys_guid() into ty_id_tmp from dual; insert into t_type select ty_id_tmp as id, type_rec.type_name from dual; -- from t_type t2 -- where t2.id = type_rec.type_id; -- commit; insert into t_templete_link select sys_guid() as id,t_id_tmp as TEMPLETE_ID ,ty_id_tmp as type_id from dual; -- t_templete_link t2 --where t2.templete_id = templete_id; commit; end loop; end; --dbms_output.put_line(t_id_tmp); exception when others then Rollback; end test3; 如果我传入的参数templete_id=1,我的t_cur循环的时候循环了3次。 但如果游标中的变变量templete_id 替换成 ‘1’就循环2次 这才是正常结果为什么

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

Python代码实现飞机大战

文章目录经典飞机大战一.游戏设定二.我方飞机三.敌方飞机四.发射子弹五.发放补给包六.主模块 经典飞机大战 源代码以及素材资料(图片,音频)可从下面的github中下载: 飞机大战源代码以及素材资料github项目地址链接 ————————————————————————————————————————————————————————— 不知道大家有没有打过飞机,喜不喜欢打飞机。当我第一次接触这个东西的时候,我的内心是被震撼到的。第一次接触打飞机的时候作者本人是身心愉悦的,因为周边的朋友都在打飞机, 每

Python数据分析与挖掘

92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元 &nbsp; 为什么学习数据分析? &nbsp; &nbsp; &nbsp; 人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。 &nbsp; &nbsp; &nbsp; 从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。 &nbsp;&nbsp; 本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。 &nbsp; 二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。 &nbsp; 三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。 &nbsp; 四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。 &nbsp; 五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。

如何在虚拟机VM上使用串口

在系统内核开发中,经常会用到串口调试,利用VMware的Virtual Machine更是为调试系统内核如虎添翼。那么怎么搭建串口调试环境呢?因为最近工作涉及到这方面,利用强大的google搜索和自己

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:csdn590)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

北京师范大学信息科学与技术学院笔试10复试真题

北京师范大学信息科学与技术学院笔试,可以更好的让你了解北师大该学院的复试内容,获得更好的成绩。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

Tomcat服务器下载、安装、配置环境变量教程(超详细)

未经我的允许,请不要转载我的文章,在此郑重声明!!! 请先配置安装好Java的环境,若没有安装,请参照我博客上的步骤进行安装! 安装Java环境教程https://blog.csdn.net/qq_40881680/article/details/83585542 Tomcat部署Web项目(一)·内嵌https://blog.csdn.net/qq_40881680/article/d...

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

图书管理系统(Java + Mysql)我的第一个完全自己做的实训项目

图书管理系统 Java + MySQL 完整实训代码,MVC三层架构组织,包含所有用到的图片资源以及数据库文件,大三上学期实训,注释很详细,按照阿里巴巴Java编程规范编写

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

微信小程序开发实战之番茄时钟开发

微信小程序番茄时钟视频教程,本课程将带着各位学员开发一个小程序初级实战类项目,针对只看过官方文档而又无从下手的开发者来说,可以作为一个较好的练手项目,对于有小程序开发经验的开发者而言,可以更好加深对小程序各类组件和API 的理解,为更深层次高难度的项目做铺垫。

[已解决]踩过的坑之mysql连接报“Communications link failure”错误

目录 前言 第一种方法: 第二种方法 第三种方法(适用于项目和数据库在同一台服务器) 第四种方法 第五种方法(项目和数据库不在同一台服务器) 总结 前言 先给大家简述一下我的坑吧,(我用的是mysql,至于oracle有没有这样的问题,有心的小伙伴们可以测试一下哈), 在自己做个javaweb测试项目的时候,因为买的是云服务器,所以数据库连接的是用ip地址,用IDE开发好...

人工智能-计算机视觉实战之路(必备算法+深度学习+项目实战)

系列课程主要分为3大阶段:(1)首先掌握计算机视觉必备算法原理,结合Opencv进行学习与练手,通过实际视项目进行案例应用展示。(2)进军当下最火的深度学习进行视觉任务实战,掌握深度学习中必备算法原理与网络模型架构。(3)结合经典深度学习框架与实战项目进行实战,基于真实数据集展开业务分析与建模实战。整体风格通俗易懂,项目驱动学习与就业面试。 建议同学们按照下列顺序来进行学习:1.Python入门视频课程 2.Opencv计算机视觉实战(Python版) 3.深度学习框架-PyTorch实战/人工智能框架实战精讲:Keras项目 4.Python-深度学习-物体检测实战 5.后续实战课程按照自己喜好选择就可以

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

2021考研数学张宇基础30讲.pdf

张宇:博士,全国著名考研数学辅导专家,教育部“国家精品课程建设骨干教师”,全国畅销书《张宇高等数学18讲》《张宇线性代数9讲》《张宇概率论与数理统计9讲》《张宇考研数学题源探析经典1000题》《张宇考

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

期末考试评分标准的数学模型

大学期末考试与高中的考试存在很大的不同之处,大学的期末考试成绩是主要分为两个部分:平时成绩和期末考试成绩。平时成绩和期末考试成绩总分一般为一百分,然而平时成绩与期末考试成绩所占的比例不同会导致出现不同

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

c语言项目开发实例

十个c语言案例 (1)贪吃蛇 (2)五子棋游戏 (3)电话薄管理系统 (4)计算器 (5)万年历 (6)电子表 (7)客户端和服务器通信 (8)潜艇大战游戏 (9)鼠标器程序 (10)手机通讯录系统

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

相关热词 c#分级显示数据 c# 不区分大小写替换 c#中调用就java c#正则表达式 验证小数 c# vscode 配置 c#三维数组能存多少数据 c# 新建excel c#多个文本框 c#怎么创建tcp通讯 c# mvc 电子病例
立即提问