假设你有两个型号。我们将它们命名为computer和log_file。
我想创建一个连接,以便始终显示所有计算机对象,但如果有相关的log_file对象,它也会添加到查询结果中。
实现这一目标的最佳方式是什么?关系:一台计算机有一个日志文件。但它有可能尚未上传到数据库。只有在我的脚本抛出错误时才会上传。
对不起我的初学者问题,我是Django的新手。
以简化模型为例:
模型1:计算机
模型2:日志文件 /每台计算机最多一次
id(pk)
mac地址
文字字段
必需查询:所有计算机的列表以及数据库中是否有任何日志文件。连接由mac地址的值组成。
认为SQL查询看起来如下所示。但是我无法用ORM翻译它。
谢谢!
答案 0 :(得分:0)
我通过使用计算字段找到了解决方法。请检查以下链接:
How to add a calculated field to a Django model
@property
以下的所有内容我在我的模型中添加了一些额外的代码:
class ConnecThor(models.Model):
# Incrementing ID (created automatically)
hostname = models.CharField(max_length=40)
MAC_address = models.CharField(max_length=17,
default='00.00.00.00.00.00', help_text="Example format: 255.255.255.255",
primary_key=True)
IP_address = models.CharField(max_length=15, default='000.000.000.000', help_text="Example format: 192.148.0.1")
config_version = models.CharField(max_length=10, default='000')
creation_date = models.DateTimeField(auto_now_add=True, null=True,
editable=False) # timezone.now() gedaan tijdens make migrations
@property
def log_file(self):
try:
return LogFiles.objects.get(MAC_address=self.MAC_address)
except LogFiles.DoesNotExist:
print('logfile not found')
class Meta(object):
db_table = 'connecthor' # table name
我的观点:
{% if connecthor.log_file %}
{% if connecthor.log_file.viewed > 0 %}
<td><a href="{% url 'show_error_log' connecthor.MAC_address %}" class="badge badge-teal">Approved</a></td>
{% else %}
<td><a href="{% url 'show_error_log' connecthor.MAC_address %}" class="badge badge-danger">Failed update</a></td>
{% endif %}
{% else %}
<td><label class="badge badge-warning">Not Found</label></td>
{% endif %}