吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1144|回复: 7
收起左侧

[求助] 关于Oracle数据库,PLSQL游标执行时日期格式转换问题

  [复制链接]
yk156511 发表于 2022-9-23 15:59
本帖最后由 yk156511 于 2022-9-24 17:48 编辑

如果单独执行查询语句 例:select min(djsj),max(djsj)  from table where bd ='具体值';
查询结果为:2017/5/24 2020/6/17 11:35:09.
但是在游标中执行后.(简写)
declare
  v_djsj table.djsj%type;
  v_djsj1 table.djsj%type;
  v_zt       table.zt%type;
begin
  for fw (select bd from table   group by bd having count(bd > 1)
  loop
    select min(djsj),max(djsj) into v_djsj,v_djsj1 from table where bd = fw.bd;
    --根据时间查询值zt
    select zt  from table where bd =fw.bd  and djsj=v_djsj1;
    if v_zt=0 then
    update ..........;
    end if;
  end loop;
  dbms_output.put_line(sql%rowcount); --受影响行数
end;
不管是to_date还是to_char都试过了。例如 select to_Date(min(djsj)).
在正常查询中是正常的,但是在游标中打印出来的都是24-MAY-17   17-JUN-20 //////2017/5/24 2020/6/17 11:35:09. (对比)。
v_s:=select zt  from table where bd =fw.bd  and djsj=v_djsj1;
因为游标执行时没有满足条件的数据了。这个djsj发生了变化、和库里的格式不一样了,查询不出结果
导致下面的v_s执行没有数据。
  v_s:=select zt  from table where bd =fw.bd  and djsj=v_djsj1;
求教,应该怎么处理。

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

yiting8 发表于 2022-9-23 16:54
请用 to_char 转换
一笑懸命桑 发表于 2022-9-24 00:00
someonewhite 发表于 2022-9-24 00:01
zhangting2022 发表于 2022-9-24 07:56
没看懂呀
simen119 发表于 2022-9-24 08:45
tochar(sysdate,'YYYY-MM-DD')
chenbaofa 发表于 2022-9-24 11:02
to——char或者to-date
lcz300400 发表于 2022-9-24 11:05
用to_char(sysdate,'yyyy-MM-dd')进行格式转换
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 06:04

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表