葬空吟 2022-01-04 15:35 采纳率: 61%
浏览 53
已结题

Oracle数据库查询语句

在MySQL中是这样写

SELECT * FROM `表1` WHERE `条件字段`='条件1' and DATE_SUB(CURDATE(), INTERVAL 7 MONTH) <= date(时间字段)

意思是,查询 表1 中 条件字段 符合 条件1 ,并且时间字段是近7个月的内容,但是在Oracle中写法不对,报ORA-00907 缺失右括号错误,正确的写法应该怎么写?
PS: 时间字段格式:2018-07-16 00:00:00 这种的
不需要计数之类的操作,就是查出近7个月的所有数据

  • 写回答

4条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-01-04 19:46
    关注
    ---如果时间字段是date类型
    SELECT * FROM1 WHERE 条件字段='条件1' and  时间字段>=add_months(trunc(sysdate),7);
    ---如果时间字段是varchar2 类型
    SELECT * FROM1 WHERE 条件字段='条件1' and  时间字段>=to_char(add_months(sysdate,7),'yyyy-mm-dd');
    
    --以上sql都是忽略时分秒的
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 2月26日
  • 已采纳回答 2月18日
  • 修改了问题 1月4日
  • 创建了问题 1月4日

悬赏问题

  • ¥15 Delphi image图片缩放问题
  • ¥30 gradle环境下javafx项目如何使用druid连接池
  • ¥15 服务器打印水晶报表问题
  • ¥15 初学者用plt报错,求解答
  • ¥18 深度学习tensorflow1,ssdv1,coco数据集训练一个模型
  • ¥100 关于注册表摄像头和麦克风的问题
  • ¥30 代码本地运行正常,但是TOMCAT部署时闪退
  • ¥15 关于#python#的问题
  • ¥15 主机可以ping通路由器但是连不上网怎么办
  • ¥15 数据库一张以时间排好序的表中,找出多次相邻的那些行