Django - 数据库数据未在应用程序中显示?

时间:2015-06-18 02:39:42

标签: python mysql django

我有一个名为'flows_db'的数据库,它维护着2个表'ingress_flows'和'egress_flows'。我做了两个表的sqldump,所以我可以使用家用电脑上的数据。所以我使用转储文件在这台计算机上重新创建表,我可以看到数据存在,因为select COUNT(*) from ingress_flows;显示有大约2000个条目。

然后我使用python manage.py inspectdb从表中创建模型。为了测试它是否有效,我试图获得一个包含表中所有条目的对象:

views.py

ingress_all = IngressFlows.objects.all()
context = {
           'ingress_all': ingress_all,
            }
return render(request, 'visualise/index.html', context)     

index.html

{% if ingress_all %}
    {% for flow in ingress_all %}
        <script>
            console.log("{{ flow.protocol }}");
        </script>
    {% endfor %}
{% else %}
    <p>No data is available.</p>
{% endif %}

但我看到的只是No data is available.。所以对于Django来说,我的数据库似乎是空的,即使我使用了包含原始数据库中所有数据的INSERT语句的转储文件:

INSERT INTO `ingress_flows` VALUES (1434506151,1434506151,'UDP',48,'ff:ff:ff:ff:ff:ff','10.30.150.100','10.30.191.255',137,137,1024,102400),...

python manage.py shell

>>> from visualise.models import IngressFlows
>>> IngressFlows.objects.all()
[]
>>> 

但我可以手动插入对象:

>>> t = IngressFlows(time_start=1434506151,time_end=1434506151,protocol='UDP',inf_in=48,mac_dst='ff:ff:ff:ff:ff:ff',ip_src='10.30.150.100',ip_dst='10.30.191.255',port_src=137,port_dst=137,packets_in=1024,bytes_in=102400)
>>> t.save()
>>> IngressFlows.objects.all()
[<IngressFlows: 1434506151, 1434506151, UDP,    48:ff:ff:ff:ff:ff:ff:10.30.150.100:10.30.191.255,   137:137,    1024,   102400>]
>>> 

Django是否维护自己的数据库而不是使用系统上的原始MySQL数据库?如果是这样,这是如何适用的,因为它不使用由其他应用程序更新的系统范围的数据库? Django如何看待这些变化:

感谢。

settings.py

DATABASES = {
    'default': {
        'ENGINE': 'mysql.connector.django',
        'NAME': 'flows_db',
        'USER': 'root',
        'PASSWORD': 'dbroot',
        'OPTIONS': {
          'autocommit': True,
        },        
    }
}

1 个答案:

答案 0 :(得分:2)

很高兴你发现了这个问题。您需要为yout Django模型设置数据库名称。 https://docs.djangoproject.com/en/1.8/ref/models/options/#db-table

class IngressFlow(models.Model):
    class Meta:
        db_table = 'ingress_flow'