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

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

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

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

suannai0314
鹳狸媛 楼主的这个问题解决了么?下边的答案能解决问题么?如果可以麻烦点击答案旁的√采纳哦~如果没有也可以将自己的答案贴上然后进行采纳的。
大约 7 年之前 回复

1个回答

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

china_3
jayung 你这个语句跟我写的那个是一样的,oracle里是rownum,SQL Server里是用top。不过还是很感谢你。
大约 7 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问