首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL NOT BETWEEN查询

SQL NOT BETWEEN查询
EN

Stack Overflow用户
提问于 2011-02-24 23:09:04
回答 2查看 37.2K关注 0票数 6

提前感谢您的任何建议或提示!

我在mysql数据库table1中有一个预订表。它包含开始日期和结束日期。我还有另一个表table2,它包含我需要获取的信息,但是只有当特定日期不在table1中任何行中的任何日期之间时才会这样。

一个例子;

代码语言:javascript
复制
select table2.testfield
FROM table2, table1
WHERE '2011-02-24 18:00:00'
NOT BETWEEN table1.start 
AND table1.finish

然而,我不能让它工作!有什么建议吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-02-24 23:12:54

这应该是可行的,但看起来应该更像

代码语言:javascript
复制
select table2.testfield
FROM table2, table1
WHERE table1.YourField = '2011-02-24 18:00:00' 
AND
NOT BETWEEN table1.start AND table1.finish

这还假设您的table1.starttable1.finish字段的类型为DateTime。如果它们不是,您可以尝试转换字段

代码语言:javascript
复制
select table2.testfield
    FROM table2, table1
    WHERE table1.YourField = '2011-02-24 18:00:00' 
    AND
    NOT BETWEEN Cast(table1.start as DateTime) AND Cast(table1.finish As DateTime)

date编辑看着你的问题,我意识到日期可能不是一个数据库值:)所以你的方法应该可以工作,但你可能需要将字符串转换为

票数 14
EN

Stack Overflow用户

发布于 2011-02-24 23:13:08

然后是这样的吗?

代码语言:javascript
复制
select table2.testfield
FROM table2, table1
WHERE 
   table1.start > convert(datetime,'2011-02-24 18:00:00')
   or table1.finish < convert(datetime,'2011-02-24 18:00:00')
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5106466

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档