Как мне сделать CLI с Django для базы данных - PullRequest
0 голосов
/ 14 ноября 2018

Я студент, и меня назначили для проекта, в котором я использую Django + PostgreSQL, и я должен создать CLI (интерфейс командной строки), возможно, с Django, показывающим мои модули базы данных. Какой самый простой способ сделать это? У меня есть только некоторые знания в программировании на C ++, поэтому я думал как оператор switch, где у пользователя есть возможность выбирать из разных запросов, но я не знаю, как это сделать в Django.

Спасибо:)

1 Ответ

0 голосов
/ 14 ноября 2018

Если вы хотите получить доступ к оболочке базы данных, просто запустите ./manage.py dbshell.Но если вы хотите отображать свои таблицы непосредственно из командной строки, вы можете использовать команду custom django management , но показ таблицы не связан с Django, а не просто использовать SQL-запрос с использованием python.Например:

Вы можете добавить новый файл Python в any_django_app/management/commands и назвать его show_tables.py, а внутри него поместить следующий код:

from django.core.management.base import BaseCommand, CommandError
from django.db import DEFAULT_DB_ALIAS, connections


class Command(BaseCommand):
    help = (
        "Shows DB tables, also you can pass your DATABASE NAME through this command"
    )

    requires_system_checks = False

    def add_arguments(self, parser):
        parser.add_argument(
            '--database', default=DEFAULT_DB_ALIAS,
            help='Nominates a database onto which to open a shell. Defaults to the "default" database.',
        )

    def handle(self, **options):
        connection = connections[options['database']]
        try:
            cursor = connection.cursor()
            cursor.execute("""SELECT table_name FROM information_schema.tables
                WHERE table_schema = 'public'""")
            for table in cursor.fetchall():
                print(table[0])
        except OSError:
            # Note that we're assuming OSError means that the client program
            # isn't installed. There's a possibility OSError would be raised
            # for some other reason, in which case this error message would be
            # inaccurate. Still, this message catches the common case.
            raise CommandError(
                'You appear not to have the %r program installed or on your path.' %
                connection.client.executable_name
            )

Теперь запустите ./manage.py show_tables, тогда он покажет таблицы из базы данных.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...