首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >返回所有不存在于另一个表中的in行。

返回所有不存在于另一个表中的in行。
EN

Stack Overflow用户
提问于 2016-11-21 07:28:49
回答 1查看 46关注 0票数 0

我在表Book中有一个行实体,比如Library。我还有一个表Borrowings,其中的行表示Borrowing实体。

Book有一个主键,它用于在Borrowing行中将图书标记为在book_id字段中借来的。可以有0-n个Borrowing行可以连接到单个Book

  • 如果某本书没有Borrowing行,那么Book是可用的。
  • 如果某本书的Borrowing行数小于当前日期,那么Book是可用的。
  • 将来只有一个带有Borrowingreturn_date行。如果这个是存在的,Book是借来的,不能供读者使用。

我的问题是-我如何找到所有可供借阅的书籍,因为它们符合这些标准?

  • 没有引用ID的Borrowing行。
  • 将来没有带有Borrowingreturn_date行。
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-21 07:37:58

尝试下面的查询

代码语言:javascript
复制
SELECT *
FROM library l
LEFT JOIN borrowing b 
 ON l.book_id = b.book_id
WHERE (b.book_id IS NULL
     OR NOW()::date - b.return_date::date > 0) 

希望这能帮到你。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40714867

复制
相关文章

相似问题

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