Вывести список имен таблиц базы данных Django из внешнего скрипта - PullRequest
0 голосов
/ 24 ноября 2018

Я пытаюсь получить доступ к базе данных sqlite3, которая есть в моем проекте Django, из внешнего скрипта, который не является частью проекта.

Однако следующее вернет пустой список:

con = sqlite3.connect('database.db')
cursor = con.cursor()
cursor.execute("SELECT name FROM sqlite_master WHERE type='table';")
print(cursor.fetchall())

Хотя я уже сохранил некоторые модели в базе данных.Чтобы проверить имена таблиц, я использую следующее в оболочке Django:

>>> tables = connection.introspection.table_names()
>>> seen_models = connection.introspection.installed_models(tables)
>>> seen_models
{<class 'django.contrib.auth.models.Permission'>, <class 'django.contrib.sessions.models.Session'>, <class 'django.contrib.contenttypes.models.ContentType'>, <class 'explorer_api.models.Athlete'>, <class 'django.contrib.admin.models.LogEntry'>, <class 'django.contrib.auth.models.Group'>, <class 'explorer_api.models.Activity'>, <class 'django.contrib.auth.models.User'>}
>>> tables
['auth_group', 'auth_group_permissions', 'auth_permission', 'auth_user', 'auth_user_groups', 'auth_user_user_permissions', 'django_admin_log', 'django_content_type', 'django_migrations', 'django_session', 'explorer_api_activity', 'explorer_api_athlete']

Я не указал явно имена таблиц в Meta модели, поэтому я предполагаю, что имена таблиц appname_modelname (explorer_api_activity иexplorer_api_athlete).

Но почему пустой список?

1 Ответ

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

Из комментариев к вопросу: Да, возможно запустить этот скрипт, если у вас есть действительный путь к файлу.Я переписал ваш скрипт с небольшими изменениями, такими как:

import sqlite3
import os.path

try:
    file_name = raw_input("Enter File Path? ")
except:
    file_name = input("Enter File Path? ")
if os.path.isfile(file_name):
    con = sqlite3.connect(file_name)
    cursor = con.cursor()
    cursor.execute("SELECT name FROM sqlite_master WHERE type='table';")
    print(cursor.fetchall())
else:
    print("File does not exist")

Использование:

> python sqlite_tables.py
  (prompt)> Enter File Path? random/file/path
  (prompt)> File does not exist

> python sqlite_tables.py
  (prompt)> Enter File Path? /valid/path/to/database.db
  (prompt)> [(u'django_migrations',), (u'sqlite_sequence',)...]

> python sqlite_tables.py
  (prompt)> Enter File Path? ../database.db  # relative path
  (prompt)> [(u'django_migrations',), (u'sqlite_sequence',)...]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...