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存储过程 截取字符串循环执行动作 急急急急!

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 存储过程 循环更新不成功

下面这个更新是在存储过程的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数据库存储过程 截取数据

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

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存储过程日期循环插入不知道错误的地方在哪。求解

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

关于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的存储过程实现查询一张表数据,放到另一张表中?

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

存储过程 使用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)

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: 列表中具有指定参数的多个实例。 一天了还是没有法解决,求大家帮忙看下。

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

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

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> ```

存储过程临时表怎循环插入表数据

ALTER PROC [dbo].[getda] @Year int = 2016 AS BEGIN SET NOCOUNT ON; SET LANGUAGE US_ENGLISH; DECLARE @TempMonth int,@SYear int,@TempDate NVARCHAR(10); SET @SYear = @Year; CREATE TABLE #TempDate ( RowID INT IDENTITY(1, 1) ,Years NVARCHAR(5) ,Months NVARCHAR(5) ,HandleID INT default(0) ,count int default(0) ); SET @TempMonth = 1; WHILE @TempMonth <= 12 BEGIN SET @TempDate = CONVERT(NVARCHAR(4),@SYear)+ '-' + CONVERT(NVARCHAR(4), @TempMonth) + '-01' ; INSERT into #TempDate(Years,Months) VALUES ( @SYear - 2000, SUBSTRING(DATENAME(MONTH, @TempDate), 1, 3)); SET @TempMonth +=1; END END select * from #TempDate GO 怎样做到实体表HandleID循环插入 想要的效果 ![图片说明](https://img-ask.csdn.net/upload/201712/04/1512377174_552176.jpg)

oracle 测试存储过程,执行一次,上次的返回结果便累加上去,如何清除?

CREATE OR REPLACE PROCEDURE PROC_Test(O_CUR OUT SYS_REFCURSOR) IS STR VARCHAR2(2000); TB_COUNT INT; BEGIN --先判断全局临时表是否存在,没存在则重新建立: SELECT COUNT(*) INTO TB_COUNT FROM USER_TABLES WHERE TABLE_NAME = UPPER('temp_table'); IF TB_COUNT = 0 THEN STR := 'CREATE GLOBAL TEMPORARY TABLE temp_table( Name VARCHAR2(100), Data VARCHAR2(500), Category VARCHAR2(200) ) ON COMMIT PRESERVE ROWS'; EXECUTE IMMEDIATE STR; END IF; STR := 'INSERT INTO temp_table(Name,Data,Category) VALUES(''省委'',100,null)'; EXECUTE IMMEDIATE STR; STR := 'INSERT INTO temp_table(Name,Data,Category) VALUES(''市委'',50,null)'; EXECUTE IMMEDIATE STR; COMMIT; STR := 'SELECT * FROM temp_table'; OPEN O_CUR FOR STR; -- 给游标变量赋值 END PROC_Test; 然后右键测试,运行,查看游标值2条数据,再运行,查看游标值就变成了4条。等大神解答

Python通过cx_Oracle调用过程,过程中的OUT游标怎么在Python中打开?怎么把游标中的列名提取出来?

调用数据库中包中的一个过程,过程头如下: ``` PROCEDURE RAITO(RETURNDS OUT REDATASET.DS, 其余IN参数 ) AS ``` 然后在Python中想用DataFrame格式显现出来,搞了半天,代码如下: ``` import cx_Oracle import pandas as pd conn = cx_Oracle.connect('mycredit/CREDIT12345@PICC_shengchan') cur = conn.cursor() i_cur = cur.var(cx_Oracle.CURSOR) zz = cur.callproc("RAITO",[i_cur, '其余IN参数']) rs = pd.DataFrame(zz) result = [] for i in range(len(rs.T)): result.append(rs[i][0]) rs2 = pd.DataFrame(result) print (rs2) ``` 结果如下: ![图片说明](https://img-ask.csdn.net/upload/201812/11/1544500592_598626.png) 有两个问题问下各位大佬: 1. ORACLE中RETURNDS(既有结果的游标)已经传入了I_CUR,各位可以看到我先把结果放到list中,再通过循环得到了上述结果,有没有比较方便的方法可以直接通过I_CUR得到结果? 2. 平常在用游标的时候我都会通过如下方法得到列名: ``` columnnames = [] for field in cursor.description: columnnames.append(field[0]) ``` 可是我在上面的列子中用如下代码的时候,就会出现错误: ``` print(i_cur.description) ``` AttributeError: 'cx_Oracle.CURSOR' object has no attribute 'description' 如果是这样的话,我怎么能取到数据库游标中的列名呢?(既RETURNDS游标中的列名)

oracle 中如何将游标中循环查出的结果集放到另外一个临时表中

## --包头 CREATE OR REPLACE PACKAGE TESTPACKAGE IS TYPE MYCURSOR IS REF CURSOR; -- 定义游标变量 -- 定义过程,用游标变量作为返回参数 PROCEDURE GETRECORDS( RET_CURSOR OUT MYCURSOR , P_BIZTYPE VARCHAR2:=NULL,-- 业务类型 P_DATE_START VARCHAR2:=NULL,-- 起始时间 P_DATE_END VARCHAR2:=NULL, -- 结束时间 P_CUSTOM_CODE VARCHAR2:=NULL--关区代码 ); END TESTPACKAGE; ## --包体 CREATE OR REPLACE PACKAGE BODY TESTPACKAGE IS /*过程体*/ PROCEDURE GETRECORDS( RET_CURSOR OUT MYCURSOR , --返回值 P_BIZTYPE VARCHAR2:=NULL,-- 业务类型 P_DATE_START VARCHAR2:=NULL,-- 起始时间 P_DATE_END VARCHAR2:=NULL, -- 结束时间 P_CUSTOM_CODE VARCHAR2:=NULL--关区代码 ) AS --ROW_DEPT CUR_CONNECTNO%ROWTYPE; --V_SQL VARCHAR2(3000);--sql语句 DAN VARCHAR2(2000); BEGIN --CUR_CONNECTNO 该游标用于存放每个业务查询出的结果集 --A业务 IF P_BIZTYPE='A' THEN CURSOR CUR_CONNECTNO IS SELECT A.ID AS GJ_NO FROM GJ_A A WHERE TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_START AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_END; END IF; --点击查询全部业务类型时,连接 /* IF P_BIZTYPE='' THEN V_SQL+=' UNION ALL ' END IF;*/ --B业务 IF P_BIZTYPE='B' THEN CURSOR CUR_CONNECTNO IS SELECT A.NO AS GJ_NO FROM GJ_B A WHERE A.I_E_MARK='1' AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_START AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_END; END IF; --M业务 IF P_BIZTYPE='M' THEN CURSOR CUR_CONNECTNO IS SELECT A.NO AS GJ_NO FROM GJ_M A WHERE SUBSTR(A.NO,3,1)='M' AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_START AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_END; END IF; /*IF P_BIZTYPE='' THEN V_STR+=' UNION ALL ' END IF;*/ --G IF P_BIZTYPE='G' THEN CURSOR CUR_CONNECTNO IS SELECT A.NO AS GJ_NO FROM GJ_G A WHERE TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_START AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_END; END IF; /*IF P_BIZTYPE='' THEN V_STR+=' UNION ALL ' END IF;*/ --E 业务 IF P_BIZTYPE='E' || P_BIZTYPE='' THEN CURSOR CUR_CONNECTNO IS SELECT A.NO AS GJ_NO FROM GJ_E A WHERE A.MARK='2' AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_START AND TO_CHAR(A.GDATETIME,'YYYY/MM/DD') >=P_DATE_END; END IF; -- 创建临时表 /* CREATE GLOBAL TEMPORARY TABLE TEMP_TBL(gj_no VARCHAR2(30),COL_A VARCHAR2(30),COL_A VARCHAR2(30)) ON COMMIT DELETE ROWS ;*/ FOR HAHA IN CUR_CONNECTNO LOOP --根据上述业务查出的数据 再在次记录表中是否 存在 ,若存在就把数据 取出来 -- 取出来 想保存到临时表中。 该怎么写 SELECT * FROM RD_Z Z WHERE BIZ_TYPE = P_BIZTYPE AND Z.NO=HAHA.GJ_NO ; END LOOP; --最后想用该游标来存放临时表中的数据集 来返回去 --OPEN RET_CURSOR FOR END GETRECORDS; END TESTPACKAGE;

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解!

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解! 目录 博客声明 大数据了解博主粉丝 博主的粉丝群体画像 粉丝群体性别比例、年龄分布 粉丝群体学历分布、职业分布、行业分布 国内、国外粉丝群体地域分布 博主的近期访问每日增量、粉丝每日增量 博客声明 因近期博主写专栏的文章越来越多,也越来越精细,逐步优化文章。因此,最近一段时间,订阅博主专栏的人数增长也非常快,并且专栏价

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

培训班出来的人后来都怎么样了?(二)

接着上回说,培训班学习生涯结束了。后面每天就是无休止的背面试题,不是没有头脑的背,培训公司还是有方法的,现在回想当时背的面试题好像都用上了,也被问到了。回头找找面试题,当时都是打印下来天天看,天天背。 不理解呢也要背,面试造飞机,上班拧螺丝。班里的同学开始四处投简历面试了,很快就有面试成功的,刚开始一个,然后越来越多。不知道是什么原因,尝到胜利果实的童鞋,不满足于自己通过的公司,嫌薪水要少了,选择...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

工作八年,月薪60K,裸辞两个月,投简历投到怀疑人生!

近日,有网友在某职场社交平台吐槽,自己裸辞两个月了,但是找工作却让自己的心态都要崩溃了,全部无果,不是已查看无回音,就是已查看不符合。 “工作八年,两年一跳,裸辞两个月了,之前月薪60K,最近找工作找的心态崩了!所有招聘工具都用了,全部无果,不是已查看无回音,就是已查看不符合。进头条,滴滴之类的大厂很难吗???!!!投简历投的开始怀疑人生了!希望 可以收到大厂offer” 先来看看网...

97年世界黑客编程大赛冠军作品(大小仅为16KB),惊艳世界的编程巨作

这是世界编程大赛第一名作品(97年Mekka ’97 4K Intro比赛)汇编语言所写。 整个文件只有4095个字节, 大小仅仅为16KB! 不仅实现了3D动画的效果!还有一段震撼人心的背景音乐!!! 内容无法以言语形容,实在太强大! 下面是代码,具体操作看最后! @echo off more +1 %~s0|debug e100 33 f6 bf 0 20 b5 10 f3 a5...

不要再到处使用 === 了

我们知道现在的开发人员都使用 === 来代替 ==,为什么呢?我在网上看到的大多数教程都认为,要预测 JavaScript 强制转换是如何工作这太复杂了,因此建议总是使用===。这些都...

什么是a站、b站、c站、d站、e站、f站、g站、h站、i站、j站、k站、l站、m站、n站?00后的世界我不懂!

A站 AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站。A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量互动弹幕,是中国弹幕文化的发源地;拥有大量超粘性的用户群体,产生输出了金坷垃、鬼畜全明星、我的滑板鞋、小苹果等大量网络流行文化,也是中国二次元文化的发源地。 B站 全称“哔哩哔哩(bilibili...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

MySQL性能优化(五):为什么查询速度这么慢

前期回顾: MySQL性能优化(一):MySQL架构与核心问题 MySQL性能优化(二):选择优化的数据类型 MySQL性能优化(三):深入理解索引的这点事 MySQL性能优化(四):如何高效正确的使用索引 前面章节我们介绍了如何选择优化的数据类型、如何高效的使用索引,这些对于高性能的MySQL来说是必不可少的。但这些还完全不够,还需要合理的设计查询。如果查询写的很糟糕,即使表结构再合理、索引再...

用了这个 IDE 插件,5分钟解决前后端联调!

点击上方蓝色“程序猿DD”,选择“设为星标”回复“资源”获取独家整理的学习资料!作者 |李海庆我是一个 Web 开发前端工程师,受到疫情影响,今天是我在家办公的第78天。开发了两周,...

大厂的 404 页面都长啥样?最后一个笑了...

每天浏览各大网站,难免会碰到404页面啊。你注意过404页面么?猿妹搜罗来了下面这些知名网站的404页面,以供大家欣赏,看看哪个网站更有创意: 正在上传…重新上传取消 腾讯 正在上传…重新上传取消 网易 淘宝 百度 新浪微博 正在上传…重新上传取消 新浪 京东 优酷 腾讯视频 搜...

【高并发】高并发秒杀系统架构解密,不是所有的秒杀都是秒杀!

网上很多的文章和帖子中在介绍秒杀系统时,说是在下单时使用异步削峰来进行一些限流操作,那都是在扯淡! 因为下单操作在整个秒杀系统的流程中属于比较靠后的操作了,限流操作一定要前置处理,在秒杀业务后面的流程中做限流操作是没啥卵用的。

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

Java14 新特性解读

Java14 已于 2020 年 3 月 17 号发布,官方特性解读在这里:https://openjdk.java.net/projects/jdk/14/以下是个人对于特性的中文式...

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

疫情后北上广深租房价格跌了吗? | Alfred数据室

去年3月份我们发布了《北上广深租房图鉴》(点击阅读),细数了北上广深租房的各种因素对租房价格的影响。一年过去了,在面临新冠疫情的后续影响、城市尚未完全恢复正常运转、学校还没开学等情况下...

面试官给我挖坑:a[i][j] 和 a[j][i] 有什么区别?

点击上方“朱小厮的博客”,选择“设为星标”后台回复&#34;1024&#34;领取公众号专属资料本文以一个简单的程序开头——数组赋值:int LEN = 10000; int[][] ...

又一起程序员被抓事件

就在昨天互联网又发生一起让人心酸的程序员犯罪事件,著名的百度不限速下载软件 Pandownload PC 版作者被警方抓获。案件大致是这样的:软件的作者不仅非法盗取用户数据,还在QQ群进...

应聘3万的职位,有必要这么刁难我么。。。沙雕。。。

又一次被面试官带到坑里面了。面试官:springmvc用过么?我:用过啊,经常用呢面试官:springmvc中为什么需要用父子容器?我:嗯。。。没听明白你说的什么。面试官:就是contr...

太狠了,疫情期间面试,一个问题砍了我5000!

疫情期间找工作确实有点难度,想拿到满意的薪资,确实要点实力啊!面试官:Spring中的@Value用过么,介绍一下我:@Value可以标注在字段上面,可以将外部配置文件中的数据,比如可以...

Intellij IDEA 美化指南

经常有人问我,你的 IDEA 配色哪里搞的,我会告诉他我自己改的。作为生产力工具,不但要顺手而且更要顺眼。这样才能快乐编码,甚至降低 BUG 率。上次分享了一些 IDEA 有用的插件,反...

【相亲】96年程序员小哥第一次相亲,还没开始就结束了

颜值有点高,条件有点好

太厉害了,终于有人能把TCP/IP 协议讲的明明白白了

一图看完本文 一、 计算机网络体系结构分层 计算机网络体系结构分层 计算机网络体系结构分层 不难看出,TCP/IP 与 OSI 在分层模块上稍有区别。OSI 参考模型注重“通信协议必要的功能是什么”,而 TCP/IP 则更强调“在计算机上实现协议应该开发哪种程序”。 二、 TCP/IP 基础 1. TCP/IP 的具体含义 从字面意义上讲,有人可能会认为...

腾讯面试题: 百度搜索为什么那么快?

我还记得去年面腾讯时,面试官最后一个问题是:百度/google的搜索为什么那么快? 这个问题我懵了,我从来没想过,搜素引擎的原理是什么 然后我回答:百度爬取了各个网站的信息,然后进行排序,当输入关键词的时候进行文档比对……巴拉巴拉 面试官:这不是我想要的答案 我内心 这个问题我一直耿耿于怀,终于今天,我把他写出来,以后再问,我直接把这篇文章甩给他!!! 两个字:倒排,将贯穿整篇文章,也是面试官...

相关热词 c#跨线程停止timer c#批量写入sql数据库 c# 自动安装浏览器 c#语言基础考试题 c# 偏移量打印是什么 c# 绘制曲线图 c#框体中的退出函数 c# 按钮透明背景 c# idl 混编出错 c#在位置0处没有任何行
立即提问