葬空吟 2022-01-04 15:35 采纳率: 60.5%
浏览 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日

悬赏问题

  • ¥20 iOS绕地区网络检测
  • ¥15 python验证码滑块图像识别
  • ¥15 根据背景及设计要求撰写设计报告
  • ¥15 QT6颜色选择对话框显示不完整
  • ¥20 能提供一下思路或者代码吗
  • ¥15 用twincat控制!
  • ¥15 请问一下这个运行结果是怎么来的
  • ¥15 单通道放大电路的工作原理
  • ¥30 YOLO检测微调结果p为1
  • ¥15 DS18B20内部ADC模数转换器