视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle动态sql参数带date类型无法执行的问题
2020-11-09 10:31:59 责编:小采
文档


之前在写存储过程时,我有一个目的是通过开始时间和结束时间来创建一个视图,于是我这么写了一个过程: procedure prc_CreateVie

之前在写存储过程时,我有一个目的是通过开始时间和结束时间来创建一个视图,于是我这么写了一个过程:

procedure prc_CreateViewOBookTcert(p_startdate in date, --统计的开始日期
p_enddate in date) --统计的结束日期
is
v_sql varchar2(2000);
begin
v_sql :=
'create or replace view v_obook_tcert as
select * from(
select
nvl(t11.region,nvl(t22.region,t33.region)) region,
nvl(t11.site,0) site,
nvl(t22.useland,0) useland,
nvl(t33.project,0) project,
nvl((nvl(t11.site,0)+nvl(t22.useland,0)+nvl(t33.project,0)),0) subtotal--统计某一区域选址、用地、工程的和
from
(select t1.项目所在区 region,count(t1.项目所在区) site--统计选址
from ts_project t1
where t1.ref_business_id=1 and t1.发证日期 between '||p_startdate||' and '||p_enddate||'
group by t1.项目所在区) t11
full join
(select t2.项目所在区 region,count(t2.项目所在区) useland--统计用地
from ts_project t2
where t2.ref_business_id=3 and t2.发证日期 between '||p_startdate||' and '||p_enddate||'
group by t2.项目所在区) t22
on t11.region=t22.region
full join
(select t3.项目所在区 region,count(t3.项目所在区) project--统计工程
from ts_project t3
where t3.ref_business_id in(5,9,11) and t3.发证日期 between '||p_startdate||' and '||p_enddate||'
group by t3.项目所在区) t33
on t22.region=t33.region)';
execute immediate v_sql;
end prc_CreateViewOBookTcert;

黄色区域是关键地方,这个过程语法是没有问题的,,把参数变量值换成实际值也是有效的。可是就是在调用的时候无效。也就是说只要把实际值用变量来代替就无效了。其实这种情况经常会出现,在 集合查询的时候也会出现这样的错误。今天突然想是不是空格什么的没注意,于是我改成了这样的:

--一书两证视图
procedure prc_CreateViewOBookTcert(p_startdate in date, --统计的开始日期
p_enddate in date) --统计的结束日期
is
v_sql varchar2(2000);
begin
v_sql :=
'create or replace view v_obook_tcert as
select * from(
select
nvl(t11.region,nvl(t22.region,t33.region)) region,
nvl(t11.site,0) site,
nvl(t22.useland,0) useland,
nvl(t33.project,0) project,
nvl((nvl(t11.site,0)+nvl(t22.useland,0)+nvl(t33.project,0)),0) subtotal--统计某一区域选址、用地、工程的和
from
(select t1.项目所在区 region,count(t1.项目所在区) site--统计选址
from ts_project t1
where t1.ref_business_id=1 and t1.发证日期 between '||chr(39)||p_startdate||chr(39)||' and '||chr(39)||p_enddate||chr(39)||'
group by t1.项目所在区) t11
full join
(select t2.项目所在区 region,count(t2.项目所在区) useland--统计用地
from ts_project t2
where t2.ref_business_id=3 and t2.发证日期 between '||chr(39)||p_startdate||chr(39)||' and '||chr(39)||p_enddate||chr(39)||'
group by t2.项目所在区) t22
on t11.region=t22.region
full join
(select t3.项目所在区 region,count(t3.项目所在区) project--统计工程
from ts_project t3
where t3.ref_business_id in(5,9,11) and t3.发证日期 between '||chr(39)||p_startdate||chr(39)||' and '||chr(39)||p_enddate||chr(39)||'
group by t3.项目所在区) t33
on t22.region=t33.region)';
execute immediate v_sql;
end prc_CreateViewOBookTcert;

可以看到变化的地方就是在变量的前后各自加了一个chr(39)(之前的也是有空格的),这个函数就是通过ascii码得到对应的字符,而39对应的就是空格,这么修改后就能够正常动态创建视图了。

很多时候大家要是遇到语法什么的一切都OK,但就是不能动态执行或者创建的时候就想一想是不是这里出了问题,比如再给游标动态传参后使用集合查询时也会出现这样的情况。

目前我还不清楚在这样的情况下为什么直接按空格键输入的空格无法使用,而通过chr(39)得到空格可以使用的原因是什么。也希望能够得到大家的帮助。

下载本文
显示全文
专题