jayung 2013-06-18 09:24 采纳率: 100%
浏览 5462
已采纳

关于证券交易日历表,获取上一个交易日的日期

已知:oracle数据有一表:trade_date 存有证券交易的日期日历(字段名tdate,类型为varchar2),只存储交易日(周末、春节、国庆等假日不在此表)。
现有一需求需要做:
判断当前日期是否是交易日?
如果是,则查找上一个交易日的日期;如果否,则不做任何处理。

我目前的思路是,先查找当天日历,如果在交易表中存在,即当天是交易日。
我查找上一交易日时,采取的思路是,在日历表中查找日期小于当前日期的记录且限定记录数为1,
select tdate from trade_date where rownum<=1 and tdate<'20130618' order by tdate desc;

大家觉得这样可行吗,或者有没有更好的思路?

  • 写回答

1条回答

  • u010618015 2013-06-18 11:58
    关注

    查找上一个交易日(我的理解是如果今天是交易日,那么就查询昨天的交易日信息,出来的结果应该就只有1个),那么个人觉得sql语句应该是这样:
    select top 1 tdate from trade_date where tdate<'20130618' order by tdate desc;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?
  • ¥15 matlab(相关搜索:紧聚焦)
  • ¥15 基于51单片机的厨房煤气泄露检测报警系统设计
  • ¥15 Arduino无法同时连接多个hx711模块,如何解决?