Если вы хотите получить доступ к оболочке базы данных, просто запустите ./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
, тогда он покажет таблицы из базы данных.