create or replace
procedure proc_dept_monthhours as
v_sql varchar2(20000):='';
v_flag number(10,0):=0;
begin
select count(*) into v_flag from user_TABLES where table_name='HO_DEPT_MONTHHOURS';
if v_flag>0 then
begin
insert into test_dept_monthhours(yearmonth,branch,subtotal)
select yearmonth,branch,sum(dm)+sum(sm)+sum(smt)+sum(sup)+sum(ltnc)
from ehruser.HO_DEPT_MONTHHOURS@traininglink
group by branch,yearmonth;
else
v_sql='create table HO_DEPT_MONTHHOURS
(
yearmonth VARCHAR2(7),
branch NVARCHAR2(200),
subtotal NUMBER
) ';
v_sql='create unique index TRDHR.HO_DEPT_MONTHHOURS_BRANCH on HO_DEPT_MONTHHOURS (BRANCH)
tablespace TRAINING_DATA
pctfree 10
initrans 2
maxtrans 255
storage
(
initial 64K
next 1M
minextents 1
maxextents unlimited
)';
v_sql='tablespace TRAINING_DATA
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 64K
next 1M
minextents 1
maxextents unlimited
)';
execute immediate v_sql;
insert into test_dept_monthhours(yearmonth,branch,subtotal)
select yearmonth,branch,sum(dm)+sum(sm)+sum(smt)+sum(sup)+sum(ltnc)
from ehruser.HO_DEPT_MONTHHOURS@traininglink
group by branch,yearmonth;
end;
end if;
commit;
end proc_dept_monthhours;为什么这个存储过程建好打叉???哪错了??
oracle,表判断是否存在,不存在则先创建表,再执行语句,存在则执行语句
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- WorldMobile 2015-10-22 13:43关注
oracle,表判断是否存在,不存在则先创建表,再执行语句,存在则执行语句
需要判断一下这个表是否存在,可以参考这个语句
--判断表是否存在,如果存在则删除
declare
num number;
begin
select count(1) into num from all_tables where TABLE_NAME = 'EMP' and OWNER='SCOTT';
if num=1 then
execute immediate 'drop table EMP';
end if;
end;本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料