Django离开了模特

时间:2018-05-21 19:02:15

标签: django django-models

假设你有两个型号。我们将它们命名为computer和log_file。

我想创建一个连接,以便始终显示所有计算机对象,但如果有相关的log_file对象,它也会添加到查询结果中。

实现这一目标的最佳方式是什么?关系:一台计算机有一个日志文件。但它有可能尚未上传到数据库。只有在我的脚本抛出错误时才会上传。

对不起我的初学者问题,我是Django的新手。

以简化模型为例:

模型1:计算机

  • id(pk)
  • 计算机名称
  • mac地址(唯一)

模型2:日志文件 /每台计算机最多一次

  • id(pk)

  • mac地址

  • 文字字段

必需查询:所有计算机的列表以及数据库中是否有任何日志文件。连接由mac地址的值组成。

认为SQL查询看起来如下所示。但是我无法用ORM翻译它。

  • SELECT *
  • 从计算机
  • LEFT JOIN登录计算机.mac_address = log_file.mac_address;

谢谢!

1 个答案:

答案 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 %}