我想知道在整个项目中多次包含模板的最佳方法,并且可能在父模板中多次包含模板。这个包含的子模板只是一个必须填充变量和 html 块的骨架。示例模板:
父.html:
<p>Popup #1</p>
{% include "popup.html" %}
<p>Popup #2</p>
{% include "popup.html" %}
Run Code Online (Sandbox Code Playgroud)
弹出窗口.html:
<h1 class="title">{% block title %}{% endblock %}</h1>
<div class="body">{% block body %}{% endblock %}</div>
Run Code Online (Sandbox Code Playgroud)
我能想到的唯一解决方案是为每个弹出窗口创建一个单独的文件,并在每个文件中扩展 popup.html。然后,我可以将这些扩展文件包含到我的父文件中。这需要为每个令人沮丧的弹出窗口添加一个文件。实现这一目标的最佳方法是什么?
我有一个疑问,我已经找到了可行的解决方案。我不确定我是否正确执行了查询,我希望找出答案。表格如下:

查询是:
q = session.query(Person).outerjoin(PetOwner).join(Animal).options(contains_eager("petowner_set"), contains_eager("petowner_set.animal"))
Run Code Online (Sandbox Code Playgroud)
将其与宠物主人连接起来的人之间存在关系。
如果连接 from persontopetowner和连接 from petownertoanimal都是内连接或都是外连接,那就很容易了。person但是,从到 的连接petowner是外连接,从petowner到 的连接animal是内连接。为了实现这一点,我添加了两个contains_eager对选项的调用。
这是完成此任务的正确方法吗?
我的模型的相关图像在这里:http://i.stack.imgur.com/xzsVU.png
我需要创建一个查询集,其中包含所有具有角色为"所有者"且名称为"bob"的关联人员的猫.
这个的sql如下所示.
select * from cat where exists
(select 1 from person inner join role where
person.name="bob" and role.name="owner");
Run Code Online (Sandbox Code Playgroud)
使用以下django过滤器可以在两个sql查询中解决此问题.
people = Person.objects.filter(name="bob", role__name="owner")
ids = [p.id for p in people]
cats = Cat.objects.filter(id__in=ids)
Run Code Online (Sandbox Code Playgroud)
我的实际设置比这更复杂,并且处理大型数据集.有没有办法用一个查询来做到这一点?如果不可能,那么有效的替代方案是什么?
我正在为每个客户重写一个包含数据库的遗留应用程序.每个客户都有自己的身份验证和用户设置.因此,我需要一个自定义身份验证后端,因为django的auth设置为仅使用默认值.我编写了中间件,在每次请求时检查URL并在那里提取信息以在请求上设置database_name.
如果我在处理自定义验证后端期间有权访问请求,我可以轻松地执行数据库调用.user = User.objects.using(request.db).get(username=username)但是,我认为没有简单的方法来实现这一点.我在这里看到了一个答案:从backend.get_user访问request.session,但这似乎不是线程安全的,所以我不想走那条路.
我能看到的仍然使用django-auth的唯一解决方案是为每个客户设置一个身份验证后端,将数据库名称设置为类属性.然后,我将创建一个自定义登录函数,将request.session ['_ auth_user_backend']设置为客户特定的后端.因此,当在每个请求上调用get_user(user_id)时,它使用客户后端,后端知道要从哪个数据库请求.
我希望尽可能避免为每个客户管理身份验证后端.有一个更好的方法吗?