Как сделать сортировку на сайте django
Можно ли установить порядок сортировки по умолчанию для модели для поля из связанной модели (а не целочисленного ключа), то есть что-то, что дает предложение SQL order by с полем из обеих моделей? Если да, то как? Я могу сделать это через query_by, но я не могу понять, как установить его по умолчанию. Спасибо.
Я использую django 1.2.7 и вместо подключения ForeignKey.Attribute мы должны использовать "__", поэтому этот код будет работать:
В качестве альтернативы order_with_respect_to (который поддерживает только одно поле), вы можете использовать настраиваемый менеджер для обеспечения заказа. Это также позволяет вам заказывать несколько полей в Foo и иметь обычный менеджер Bar.objects. Вам нужно будет проверить, применяется ли сначала заказ Meta.Addinging или заказного менеджера.
hmm. Я решаю аналогичную вещь, повышая эффективность старого приложения django, написанного до qs-rf, где, вероятно, использовалась "точка", обозначенная. мне потребовалось несколько часов, чтобы разложить "что-то", и я до сих пор не уверен, но. попытайтесь заменить точку "__" (двойные подчеркивания), это может помочь. На самом деле, curentlly, я все еще НАДЕЖДА СЛИШКОМ: -)))
@stuart: для "order_with_respect_to" я прочитал что-то о автоматически добавленном физическом поле модели в дочернюю таблицу. Я не понимаю, как все здесь. Документация IMHO очень плохо о упорядочении синтаксиса, howgh!
В любом случае, мне нравится Django, но. -))
В современной версии django это:
Либо вы можете изменить количество пробелов перед именем класса, как указано выше, или заказать его с помощью чисел, как показано ниже:
Посмотрите другие вопросы по меткам django django-models или Задайте вопрос
В этой главе ты узнаешь как Django подключается к базе данных и сохраняет в неё информацию. Давай начнем!
Что такое QuerySet?
QuerySet, по сути, список объектов заданной Модели. QuerySet позволяет читать данные из базы данных, фильтровать и изменять их порядок.
Проще научиться на примере. Давай попробуем, согласна?
Интерактивная консоль Django
Открой свой локальный терминал (не на PythonAnywhere), и набери следующую команду:
Результат должен быть таким:
Ты находишься в интерактивной консоли Django. По сути, это та же интерактивная консоль Python, но с магией Django :). Ты можешь использовать весь синтаксис Python, разумеется.
Все объекты
Давай попробуем вывести на экран все записи в нашем блоге. Ты можешь сделать это следующей командой:
Упс! Ошибка. Она говорит, что не существует объекта с именем Post. И это верно -- мы забыли импортировать его!
Все просто: мы импортируем модель Post из blog.models . Давай попробуем получить все записи блога еще раз:
Это список записей, с которыми мы работали до этого! Мы создали их через панель администратора Django. Теперь же, мы хотим создавать записи через Python, так как же мы этого добьемся?
Создаем объект
Создать объект Post в базе данных можно следующим образом:
Но у нас есть один недочет: me . Мы должны передать этой переменной экземпляр модели User , который будет отвечать за автора записи. Как это сделать?
Давай импортируем модель user для начала:
Какие пользователи есть в нашей базе данных? Попробуй эту команду:
Это суперпользователь, которого мы создали ранее! Нам нужен его экземпляр:
Как ты можешь заметить, мы получили ( get ) пользователя ( User ) с именем username 'ola'. Шикарно! В твоем случае, имя, конечно, может отличаться.
Теперь мы наконец можем создать наш пост:
Ура! Хочешь проверить, что все работает?
Есть, еще один пост в списке!
Добавляем записи
Можешь повеселиться и добавить еще записей. 2-3 будет достаточно.
Фильтрация объектов
Важной особенностью QuerySets является возможность фильтровать объекты. Предположим, нам нужно найти все записи пользователя ola. Мы используем метод filter вместо метода all в Post.objects.all() . В кавычках мы укажем условия, по которым будет построена выборка записей. В нашей ситуации условием будет являться равенство поля author переменной me . В Django мы можем написать это следующим образом: author=me . Теперь наш код выглядит следующим образом:
А может быть мы хотим получить все записи со словом 'title' в поле title ?
Примечание: Обрати внимание на два символа нижнего подчеркивания ( _ ) между title и contains . Django's ORM использует этот синтаксис для разделения имен полей ("title") и операций или фильтров ("contains"). Если ты используешь только один символ нижнего подчеркивания, то получишь ошибку "FieldError: Cannot resolve keyword title_contains".
Ты также можешь получить список всех опубликованных записей. Мы просто отфильтруем записи по полю published_date :
К сожалению, пост, который мы добавили в консоли Python еще не опубликован. Мы можем изменить это! Сначала выберем запись, которую мы хотим опубликовать:
Дальше мы опубликуем её с помощью метода publish !
Сортировка объектов
QuerySets позволяет сортировать объекты. Давай попробуем сортировку по полю created_date :
Мы также можем изменить порядок на противоположный, добавив - в начало условия:
Соединение QuerySets
QuerySets можно сцеплять, создавая цепочки:
Это — мощный и удобный инструмент, позволяющий писать сложные запросы.
Отлично! Теперь ты готова к следующей части! Чтобы закрыть интерактивную консоль, набери:
Я использую Django 1.5.1, и сейчас у меня есть таблица, показывающая содержимое из базы данных, так что я в основном делаю это печать строк из базы данных на веб-страницу.
Чтобы распечатать каждую строку из базы данных, я использую следующий код
Сейчас он распечатывает содержимое в порядке возрастания идентификатора, но то, что я хочу, это распечатать в порядке убывания идентификатора. Так что в основном вместо 1 2 3, и я хочу, чтобы это прошло 3 2 1 (если это имеет смысл).
Я считаю, что это будет иметь какое-то отношение к этому для линии цикла, но я не уверен.
В этой статье показано, как определить модели для LocalLibrary сайта. Она объясняет, что такое модель, как она объявляется, и некоторые из основных типов полей. В ней также кратко показаны некоторые из основных способов доступа к данным модели.
Предпосылки | Django Tutorial Part 2: Creating a skeleton website. |
---|---|
Задача: | Научиться проектировать и создавать свои собственные модели, выбирая подходящие поля. |
Обзор
Веб-приложения Django получают доступ и управляют данными через объекты Python, называемые моделями. Модели определяют структуру хранимых данных, включая типы полей и, возможно, их максимальный размер, значения по умолчанию, параметры списка выбора, текст справки для документации, текст меток для форм и т. д. Определение модели не зависит от основной базы данных - вы можете выбрать один из нескольких компонентов вашей настройки проекта. После того, как вы выбрали какую базу данных хотите использовать, вам не нужно напрямую работать с ней - вы просто пишете свою структуру модели и код, а Django делает всю грязную работу, связанную с базой данных за вас.
В этом учебнике показано, как определить и получить доступ к моделям на примере LocalLibrary website.
Проектирование моделей LocalLibrary
Перед тем, как вы начнёте программировать модели, стоит потратить несколько минут, чтобы подумать о том, какие данные нам нужно хранить, и о взаимоотношениях между разными объектами.
Мы знаем, что нам нужно хранить информацию о книгах (название, резюме, автор, язык, на котором написана книга, категория, ISBN) и что у нас может быть несколько доступных экземпляров (с уникальным глобальным идентификатором, статусом доступности и т. Д.). Нам может потребоваться хранить больше информации об авторе, чем просто их имя, и могут быть несколько авторов с одинаковыми или похожими именами. Мы хотим иметь возможность сортировать информацию на основе названия книги, автора, письменного языка и категории.
Как только мы определились с нашими моделями и полями, нам нужно подумать об отношениях. Django позволяет вам определять отношения, как один к одному ( OneToOneField ), один ко многим ( ForeignKey ) и многие ко многим ( ManyToManyField ).
Диаграмма ассоциации UML, приведённая ниже показывает модели, которые мы определили в этом случае (в виде блоков). Как и выше, мы создали модели для книги (общие сведения о книге), экземпляр книги (статус конкретных физических копий книги, доступных в системе) и автора.Мы также решили создать модель для жанра, чтобы можно было создавать / выбирать значения через интерфейс администратора. Мы решили не иметь модель для BookInstance: status - мы жёстко закодировали значения (LOAN_STATUS), потому что мы не ожидаем их изменения. В каждом из полей вы можете увидеть имя модели, имена и типы полей, а также методы и их типы возврата.
На диаграмме также показаны зависимости между моделями, включая их множители. Множители представляют собой числа на диаграмме, показывающие минимум и максимум единиц каждой модели, которые могут присутствовать в этой связи. Например, соединительная линия между ящиками показывает, что книга и жанр связаны между собой. Цифры, близкие к модели жанра, показывают, что у книги может быть один или несколько жанров (сколько угодно), а числа на другом конце строки рядом с моделью книги показывают, что у жанра может быть ноль или более связанных книг.
Примечание. В следующем разделе приведён базовый пример, поясняющий, как модели определяются и используются. Когда вы его прочитаете, подумайте, как мы построим каждую из моделей на диаграмме выше.
Модель для начинающих
В этом разделе представлен краткий обзор того, как определяется модель, и некоторые из наиболее важных полей и аргументы поля.
Определение модели
В следующих разделах мы подробно рассмотрим каждый элемент внутри модели:
Модель может иметь произвольное количество полей любого типа - каждый представляет столбец данных, который мы хотим сохранить в одной из наших таблиц базы данных. Каждая запись (строка) базы данных будет состоять из одного значения каждого поля. Давайте рассмотрим приведённый выше пример:
- max_length=20 — Указывает, что максимальная длина значения в этом поле составляет 20 символов.
- help_text="Enter field documentation" — предоставляет текстовую метку для отображения, чтобы помочь пользователям узнать, какое значение необходимо предоставить, когда это значение должно быть введено пользователем через HTML-форму.
Имя поля используется для обращения к нему в запросах и шаблонах. В полях также есть метка, которая задаётся как аргумент (verbose_name), либо выводится путём заглавной буквы первой буквы имени переменной поля и замены любых символов подчёркивания пробелом (например, my_field_name будет иметь метку по умолчанию My field name).
Порядок, в котором объявляются поля, будет влиять на их порядок по умолчанию, если модель отображается в форме (например, на сайте администратора), хотя это может быть переопределено.
Общие аргументы поля
Следующие общие аргументы могут использоваться при объявлении многих / разных типов полей:
-
: Предоставляет текстовую метку для HTML-форм (например, на сайте администратора), как описано выше. : Удобочитаемое имя для поля, используемого в поле метки. Если не указано, Django выведет по умолчанию подробное название от имени поля. : Значение по умолчанию для поля. Это может быть значение или вызываемый объект, и в этом случае объект будет вызываться каждый раз, когда создаётся новая запись. : Если True, Django будет хранить пустые значения как NULL в базе данных для полей, где это уместно (CharField вместо этого сохранит пустую строку). По умолчанию используется значение False. : Если True, поле может быть пустым в ваших формах. По умолчанию используется значение False, что означает, что проверка формы Django заставит вас ввести значение. Это часто используется с null = True, потому что если вы хотите разрешить пустые значения, вы также хотите, чтобы база данных могла представлять их соответствующим образом. : Группа вариантов для этого поля. Если это предусмотрено, по умолчанию соответствующий виджет формы будет полем выбора с этими вариантами вместо стандартного текстового поля. : Если True, задаёт текущее поле в качестве первичного ключа для модели (первичный ключ - это специальный столбец базы данных, предназначенный для однозначной идентификации всех разных записей таблицы). Если в качестве первичного ключа не указано поле, Django автоматически добавит для этой цели поле.
Есть много других вариантов - вы можете просмотреть full list of field options here.
Общие типы полей
Следующие общие аргументы могут использоваться при объявлении многих / разных типов полей:
Метаданные
Вы можете объявить метаданные на уровне модели для своей модели, объявив класс Meta, как показано на рисунке.
Одной из наиболее полезных функций этих метаданных является управление сортировка записей, возвращаемых при запросе типа модели. Вы можете сделать это, указав соответствия названия полей для сортировки, как показано выше. Порядок будет зависеть от типа поля (поля символов отсортированы в алфавитном порядке, а поля даты отсортированы в хронологическом порядке). Как показано выше, вы можете префикс имени поля минус-символом (-), чтобы изменить порядок сортировки.
Например, если мы решили сортировать книги по умолчанию:
Книги будут отсортированы по алфавиту по названию, от A-Z, а затем по дате публикации внутри каждого названия, от самого нового до самого старого.
Другим распространённым атрибутом является verbose_name, подробное имя для класса в единственной и множественной форме:
Методы
Модель также может иметь методы. Минимально в каждой модели вы должны определить стандартный метод класса для Python __str __ (), чтобы вернуть удобочитаемую строку для каждого объекта. Эта строка используется для представления отдельных записей на сайте администрирования (и в любом другом месте, где вам нужно обратиться к экземпляру модели). Часто это возвращает поле названия или имени из модели.
Конечно, для выполнения этой работы вам всё равно придётся писать сопоставление URL-адрес, просмотр и шаблон!
Вы также можете определить любые другие методы, которые вам нравятся, и вызывать их из вашего кода или шаблонов (при условии, что они не принимают никаких параметров).
Управление моделью
После того, как вы определили свои классы моделей, вы можете использовать их для создания, обновления или удаления записей и для запуска запросов для получения всех записей или отдельных подмножеств записей. Мы покажем вам, как это сделать в учебнике, когда мы определяем наши представления, с кратким обзором.
Создание и изменение записей
Чтобы создать запись, вы можете определить экземпляр модели, а затем вызвать метод save ().
Примечание. Если вы не указали какое-либо поле в качестве primary_key, новая запись будет выдаваться автоматически, с идентификатором имени поля. Вы можете запросить это поле после сохранения указанной выше записи, и оно будет иметь значение 1.
Вы можете получить доступ к полям в этой новой записи с использованием синтаксиса точек и изменить значения. Вы должны вызвать save (), чтобы сохранить изменённые значения в базе данных.
Поиск записей
Вы можете искать записи, соответствующие определённым критериям, используя атрибут объектов модели (предоставляемый базовым классом).
Мы можем получить все записи для модели как объект QuerySet, используя objects.all() . QuerySet - это итерируемый объект, означающий, что он содержит несколько объектов, которые мы можем перебирать / прокручивать.
Соответствующие поля и тип соответствия определяются в имени параметра фильтра, используя формат: field_name__match_type (обратите внимание на двойное подчёркивание между заголовком выше). Выше мы фильтруем заголовок с учётом регистра. Есть много других типов совпадений, которые вы можете сделать: icontains (без учёта регистра), iexact (точное совпадение без учёта регистра), exact (точное совпадение с учётом регистра ) и in , gt (больше), startswith и т. д смотреть полный список (Django Docs, [EN]).
Существует гораздо больше возможностей для запросов, включая обратные поиски от связанных моделей, цепочки фильтров, возврат меньшего набора значений и т. д. Для получения дополнительной информации см. Making queries (Django Docs, [EN]).
Определение моделей LocalLibrary
В этом разделе мы начнём определять модели для библиотеки. Откройте models.py (в / locallibrary / catalog /). Шаблон в верхней части страницы импортирует модуль моделей, который содержит базовый класс модели models.Model , от которого наследуются наши модели.
Модель жанра
Скопируйте приведённый ниже код модели Genre и вставьте его в нижнюю часть вашего файла models.py . Эта модель используется для хранения информации о категории книг - например, будь то художественная или документальная, роман или военно-историческая и т. д. Как уже упоминалось выше, мы создали жанр как модель, а не как свободный текст или список выбора, чтобы возможные значения могли управляться через базу данных, а не были закодированными.
Модель имеет один CharField field (имя), которое используется для описания жанра (оно ограничено 200 символами и имеет некоторый help_text . В конце модели мы объявляем метод __str__() , который просто возвращает имя жанра, определённого конкретной записью. Verbose name не был определён, поэтому поле будет называться Name в формах.
Модель книги
Жанр представляет из себя ManyToManyField, так что книга может иметь несколько жанров, а жанр может иметь много книг. Автор объявляется через ForeignKey, поэтому в каждой книге будет только один автор, но у автора может быть много книг (на практике книга может иметь несколько авторов, но не в такой реализации!)
В обоих типах полей соответствующий класс модели объявляется как первый неименованный параметр, используя либо класс модели, либо строку, содержащую имя соответствующей модели. Вы должны использовать имя модели как строку, если связанный класс ещё не был определён в этом файле до того, как он будет указан! Другими параметрами, представляющими интерес для поля автора, являются null=True , которое позволяет базе данных хранить значение Null , если автор не выбран, и on_delete = models. SET_NULL установит значение автора в Null, если связанная с автором запись будет удалена.
Модель также определяет __str __ (), используя поле заголовка книги для представления книги. Окончательный метод get_absolute_url () возвращает URL-адрес, который можно использовать для доступа к подробной записи для этой модели (для этого нам нужно будет определить сопоставление URL-адресов, в котором содержится подробная информация о книге, и определить связанное представление и шаблон ).
Модель BookInstance
- ForeignKey для идентификации связанной книги (в каждой книге может быть много копий, но в копии может быть только одна книга).
- CharField, для представления данных (конкретного выпуска) о книге.
Мы дополнительно объявляем несколько новых типов полей:
Модель __str __ () представляет объект BookInstance, используя комбинацию его уникального идентификатора и связанного с ним заголовка книги.
Примечание. Немного Python:
-
Значение, возвращаемое __str __ (), является форматированной строкой. В строке мы используем % S для объявления 'placeholders'. После строки укажем %, а затем кортеж, содержащий значения, которые будут вставлены в заполнители. Если у вас просто один заполнитель, вы можете опустить кортеж - например, 'Моё значение:% S' % переменная.
Модель автора
Скопируйте модель автора (показано ниже) под существующим кодом в models.py.
Теперь все поля/методы должны быть знакомы. Модель определяет автора как имя, фамилию, дату рождения и (необязательную) дату смерти. Он указывает, что по умолчанию __str __ () возвращает имя в фамилии, порядковый номер первого имени. Метод get_absolute_url () отменяет сопоставление URL-адреса автора с целью получения URL-адреса для отображения отдельного автора.
Повторно выполнить миграцию базы данных
Теперь все ваши модели созданы. Теперь переустановите миграцию базы данных, чтобы добавить их в свою базу данных.
Языковая модель - вызов
Представьте себе, что местный благотворитель жертвует ряд новых книг, написанных на другом языке (скажем, фарси). Задача состоит в том, чтобы определить, как они будут лучше всего представлены на нашем веб-сайте библиотеки, а затем добавить их в модели.
Некоторые вещи, которые следует учитывать:
После того, как вы решили, добавьте поле. Вы можете увидеть наше решение на Github here.
Резюме
В этой статье мы узнали, как определять модели, а затем использовать эту информацию в разработке и внедрении соответствующих моделей для сайта LocalLibrary.
На этом этапе мы отвлечёмся от создания сайта и проверим Django Administration site. Этот сайт позволит нам добавить некоторые данные в библиотеку, которые мы можем отобразить с помощью наших (ещё не созданных) представлений и шаблонов.
Читайте также: