FAQ: Bancos de Dados e modelos

Como posso ver as consultas SQL que o Django está executando?

Assegure que sua configuração do Django DEBUG está configurada para True. Então faça isso:

>>> from django.db import connection
>>> connection.queries
[{'sql': 'SELECT polls_polls.id, polls_polls.question, polls_polls.pub_date FROM polls_polls',
'time': '0.002'}]

“connection.queries” só está disponível se nas configurações a variável DEBUG for True. É uma lista de dicionários em ordem de execução da querie. Cada dicionário possui o seguinte:

``sql`` -- The raw SQL statement
``time`` -- How long the statement took to execute, in seconds.

connection.queries incluem todas as instruções SQL - INSERTs, UPDATEs, SELECTs etc. Cada vez que seu aplicativo atinge o banco de dados a consulta será gravada.

Se você estiver usando múltiplos banco de dados, você pode usar a mesma interface em cada membro de dicionário de conexões:

>>> from django.db import connections
>>> connections['my_db_alias'].queries

If you need to clear the query list manually at any point in your functions, call reset_queries(), like this:

from django.db import reset_queries
reset_queries()

Posso usar o Django em um banco de dados pré-existente?

Sim. Veja a documentação: Integrando com um banco de dados legado.

Como eu faço para atualizar o banco de dados, se eu fizer alterações em um modelo?

Dê uma olhada no suporte do Django para migrações de schema.

Se você não se importa de limpar os dados, o utilitário manage.py do seu projeto tem uma opção flush para redefinir o banco de dados para o estado em que estava imediatamente depois que o migrate foi executado.

O modelo do Django suporta chaves primárias de várias colunas?

Não. Apenas chaves primárias de coluna única são suportadas.

But this isn’t an issue in practice, because there’s nothing stopping you from adding other constraints (using the unique_together model option or creating the constraint directly in your database), and enforcing the uniqueness at that level. Single-column primary keys are needed for things such as the admin interface to work; e.g., you need a single value to specify an object to edit or delete.

Django suporta banco de dados NoSQL?

NoSQL databases are not officially supported by Django itself. There are, however, a number of side projects and forks which allow NoSQL functionality in Django.

You can take a look on the wiki page which discusses some projects.

Como eu adiciono uma opção específica de base de dados à minha cláusula CREATE TABLE, tipo especificando MyISAM como tipo de tabela?

Nós tentamos evitar ao adicionar casos excepcionais ao código do Django para acomodar todas as opções específicas de cada banco de dados, como: tipo de tabela e etc. . Se você quiser usar qualquer uma destas opções específicas crie uma rotina de migração com a classe RunSQL contendo a instrução ALTER TABLE e realizando a operação que você deseja.

Por exemplo, se você está usando MySQL e quiser que suas tabelas usem a tabela do tipo MyISAM, use a seguinte instrução SQL:

ALTER TABLE myapp_mytable ENGINE=MyISAM;
Back to Top