TSQL查询Python Flask项目 - python

[表TSQL查询Python Flask项目 - python s]

我正在努力为星期一的学校做一个项目。我有2个表(用户和书),这些表与我称为“收藏夹”的连接器表具有多对多关系。我正在网页(python / flask / jinja)中显示书籍标题,并且有一个查询可以显示所有书籍标题,但是问题是,如果必须在每本书下面添加一个链接(添加到收藏夹),当前登录的用户不喜欢该特定书。

我需要这是要显示在同一div中的一个查询。

我的表格链接在上面的图像链接中。

我的选择查询

select *  from users  join favorites on users.id = favorites.user_id  join books on books.id = favorites.book_id

我遇到的问题是当我有一本当前用户和另一个用户喜欢的书时。如何过滤未登录用户喜欢的书?

参考方案

您的查询选择所有用户与其书本之间的关系。如果您只想查找当前用户喜欢的书,则应使用“ WHERE”子句:

select *  from users 
join favorites on users.id = favorites.user_id 
join books on books.id = favorites.book_id 
where users.id = current_user_id

编辑:

如果要显示所有书籍并显示特定用户喜欢的书籍:

select b.*,u.* from books as b
left join favorites as f on f.book_id = b.id
left join users as u on u.id = f.user_id and u.id = current_user_id
group by b.id

如果当前用户没有该书作为收藏夹,则users列将为null。

您还可以创建一个表示收藏夹状态的列:

select b.*,u.*,IF(u.id is null,0,1) as favorited
from books as b
left join favorites as f on f.book_id = b.id
left join users as u on u.id = f.user_id and u.id = current_user_id
group by b.id

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

Python exchangelib在子文件夹中读取邮件 - python

我想从Outlook邮箱的子文件夹中读取邮件。Inbox ├──myfolder 我可以使用account.inbox.all()阅读收件箱,但我想阅读myfolder中的邮件我尝试了此页面folder部分中的内容,但无法正确完成https://pypi.python.org/pypi/exchangelib/ 参考方案 您需要首先掌握Folder的myfo…

python-docx应该在空单元格已满时返回空单元格 - python

我试图遍历文档中的所有表并从中提取文本。作为中间步骤,我只是尝试将文本打印到控制台。我在类似的帖子中已经看过scanny提供的其他代码,但是由于某种原因,它并没有提供我正在解析的文档的预期输出可以在https://www.ontario.ca/laws/regulation/140300中找到该文档from docx import Document from…

Python ThreadPoolExecutor抑制异常 - python

from concurrent.futures import ThreadPoolExecutor, wait, ALL_COMPLETED def div_zero(x): print('In div_zero') return x / 0 with ThreadPoolExecutor(max_workers=4) as execut…