oracle数据库job怎么调用含参数的存储过程?
具体代码如下:--建表createtabletest_job(namevarchar2);commit;-建立存储过程createorreplaceprocedurete...
具体代码如下:
--建表
create table test_job(name varchar2);
commit;
-建立存储过程
create or replace procedure test_jobproce
(
name In varchar2
)as
begin
insert into test_job values(name);
end test_jobproce;
--建立job
--建立job后默认是执行的
declare test_job_really number;
begin
dbms_job.submit(test_job_really,'test_jobproce("zhangsan");',sysdate,'sysdate+1/1440');
commit;
end;
这里建立job时就报错,具体内容如下(这里不要看具体的表名和列名,因为保密原则我把表明和具体的列改为一个简单的例子,但是数据类型和格式都一样,希望大神分析原因):
第 1 行出现错误:
ORA-06550: line 1, column 116:
PLS-00201: identifier 'zhangsan' must be declared
ORA-06550: line 1, column 93:
PL/SQL: Statement ignored
ORA-06512: at "SYS.DBMS_JOB", line 82
ORA-06512: at "SYS.DBMS_JOB", line 139
ORA-06512: at line 4
---查询job
select job ,what from dba_jobs;
--假设job的id为25
--启动job
begin
dbms_job.run(25);
commit;
end;
这段程序,在创建job时就出错了。
哪位大神能给一个成功的Oracle数据库job调用带参数的存储过程的例子?谢谢了。 展开
--建表
create table test_job(name varchar2);
commit;
-建立存储过程
create or replace procedure test_jobproce
(
name In varchar2
)as
begin
insert into test_job values(name);
end test_jobproce;
--建立job
--建立job后默认是执行的
declare test_job_really number;
begin
dbms_job.submit(test_job_really,'test_jobproce("zhangsan");',sysdate,'sysdate+1/1440');
commit;
end;
这里建立job时就报错,具体内容如下(这里不要看具体的表名和列名,因为保密原则我把表明和具体的列改为一个简单的例子,但是数据类型和格式都一样,希望大神分析原因):
第 1 行出现错误:
ORA-06550: line 1, column 116:
PLS-00201: identifier 'zhangsan' must be declared
ORA-06550: line 1, column 93:
PL/SQL: Statement ignored
ORA-06512: at "SYS.DBMS_JOB", line 82
ORA-06512: at "SYS.DBMS_JOB", line 139
ORA-06512: at line 4
---查询job
select job ,what from dba_jobs;
--假设job的id为25
--启动job
begin
dbms_job.run(25);
commit;
end;
这段程序,在创建job时就出错了。
哪位大神能给一个成功的Oracle数据库job调用带参数的存储过程的例子?谢谢了。 展开
3个回答
光点科技
2023-08-15 广告
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件...
点击进入详情页
本回答由光点科技提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询