Перебор столбца базы данных в Django - PullRequest
0 голосов
/ 07 апреля 2010

Я хотел бы выполнить итерацию по столбцу значений в базе данных MySQL.Интересно, есть ли в Django какие-либо встроенные функции для этого?Ранее я просто использовал следующее для хранения каждого столбца в виде списка кортежей с именем table_column:

import MySQLdb
import sys

try:
    conn = MySQLdb.connect (host = "localhost",
                            user = "user",
                            passwd="passwd",
                            db="db")
except MySQLdb.Error, e:
    print "Error %d: %s" % (e.args[0], e.args[1])
    sys.exit (1)

cursor = conn.cursor()

for table in ['foo', 'bar']:
    for column in ['foobar1', 'foobar2']:
        cursor.execute('select %s from %s' % (column, table))
        exec "%s_%s = cursor.fetchall()" % (table, column)

cursor.close()

conn.commit()
conn.close()

Есть ли какая-либо функциональность, встроенная в Django, для более удобной итерации значений столбца втаблица базы данных?Я имею дело с миллионами строк, поэтому скорость выполнения важна.

[решено] Спасибо всем.Я использовал встроенный итератор в сочетании с вызовом values_list () для оптимизации производительности.Обратите внимание, что вызов values ​​() будет возвращать dicts, который медленно повторяется, тогда как values_list () возвращает намного более быстрые кортежи.Так, например, если я хочу выполнить итерацию по каждой строке столбца 'foobar1', в таблице 'foo' я могу получить итератор следующим образом:

foobar1_iterator = foo.objects.values_list('foobar1').iterator()

Предположим, я хочуитерации по i, чтобы получить список всех значений строки 'foobar1'.Тогда просто сделайте это:

foobar1_list = [i for i in foobar1_iterator]

Ответы [ 3 ]

1 голос
/ 07 апреля 2010

Микрооптимализация базы данных не является сильной частью Django ORM. Однако, когда скорость так важна, я задаюсь вопросом, является ли exec правильный способ сделать это.

В любом случае, вы пишете «перебирать значения столбца», это означает, что у вас есть несколько значений в одном столбце, разделенных разделителем (не видно в вашем коде)?

Тогда просто

for value in modelinstalnce.column.split('seprator'):
    print 'whatever'

Что касается связи, лучше использовать

from django.db import connection

вместо того, чтобы делать это вручную.

Что касается пар, я бы сделал что-то вроде:

pairs = []

for model in (MyModel, MyModel2,):
    for field in model.field_names:
        pairs.append((field, getattr(model, field))
1 голос
/ 08 апреля 2010
1 голос
/ 07 апреля 2010
from django.db.models.loading import get_model
app_name = 'your_app_name'
for model_name in ['foo','bar']:
    model = get_model(app_name, model_name)
    model_values = model.objects.values('foorbar1','foobar2') # this is a ValuesQuerySet. 
                                                              # you can run your computation on it, 
                                                              # or store the values somewhere.
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...