【问题标题】:Selecting data not matching query选择不匹配查询的数据
【发布时间】:2013-04-25 09:49:44
【问题描述】:

我只想选择与查询不匹配的数据。

假设我有两张桌子:

汽车:

id         int          PRIMARY KEY IDENTITY
make       varchar(255) NOT NULL
model      varchar(255) NOT NULL
pricegroup varchar(1)   NOT NULL

租金:

id         int          PRIMARY KEY IDENTITY
sdate      date         NOT NULL
edate      date         NOT NULL
car_id     int          NOT NULL

Rentals 中的

sdate 是租赁的开始日期 - edate 是结束日期。

我想查找指定时间段内所有可用的汽车。

这个查询几乎可以工作:

SELECT * FROM cars WHERE id NOT IN 
  (SELECT car_id FROM rentals WHERE sdate <='2013-04-28' AND edate >='2013-04-30')

但是,它仅适用于特定日期。如果您输入 2013-04-252013-05-30 之间的时间段,所有汽车都会显示,即使其中一些在此期间已被预订。 p>

我使用 MS SQL 2012。

【问题讨论】:

    标签: sql date select sql-server-2012


    【解决方案1】:

    你需要反过来比较日期:

    SELECT * FROM cars WHERE id NOT IN 
      (SELECT car_id FROM rentals WHERE sdate <='2013-04-30' AND edate >='2013-04-28')
    

    另外,使用NOT EXISTS 可能会比NOT IN 提供更好的性能:

    SELECT * FROM cars WHERE NOT EXISTS
      (SELECT 1 FROM rentals WHERE car_id=cars.id AND edate>=start_date AND sdate<=end_date)
    

    【讨论】:

      【解决方案2】:

      将所有日期转换为日期时间格式,时间为 0(即 2013-04-28 00:00:00.000 )。

      SELECT * FROM cars WHERE id NOT IN
      (SELECT car_id FROM rentals WHERE 
          Convert(datetime, Convert(varchar(12),sdate,106)) as sdate >= Convert(datetime, Convert(varchar(12),'2013-04-28',106)) AND 
          Convert(datetime, Convert(varchar(12),edate,106)) as edate <= Convert(datetime, Convert(varchar(12),'2013-04-30',106)))
      

      【讨论】:

      • 为什么有必要这样做?
      • 如果您有这样的日期,即 2013-04-28 12:39:12.000。如果您使用 where sdate = 2013-04-28 之类的 where 查询,则无法获取此日期。我遇到了这样的问题,所以我总是转换成这种格式 2013-04-28 00:00:00.000
      • 好吧,我数据库中插入的日期只是日期,根本没有时间,所以这里应该不是问题。
      • 呵呵。那么你没有问题。但是你可以像这样使用输入 Convert(datetime, '2013-04-30')
      • 这是一些有用的输入 :)
      猜你喜欢
      • 2020-02-22
      • 2013-07-17
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-07-19
      • 2021-06-04
      相关资源
      最近更新 更多