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调用带参数的存储过程的例子?谢谢了。
展开
 我来答
sunny_swufe
推荐于2017-09-12 · TA获得超过131个赞
知道答主
回答量:74
采纳率:0%
帮助的人:57.5万
展开全部
dbms_job.submit(test_job_really,'test_jobproce("zhangsan");',sysdate,'sysdate+1/1440');

改为:
dbms_job.submit(test_job_really,'test_jobproce(''zhangsan'');',sysdate,'sysdate+1/1440');

注意:zhangsan的两边,不是双引号,是两个单引号!

如有帮助,请采纳!
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
jackylvxg
2014-03-06 · TA获得超过243个赞
知道小有建树答主
回答量:386
采纳率:0%
帮助的人:220万
展开全部
sql里的引号全部是单引号
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2014-03-06
展开全部
请问你的代码呢?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式