FAQ: Basisdata dan model

Bagaimana dapat Saya melihat permintaan SQL mentah sedang berjalan?

Pastikan setelan Django DEBUG disetel menjadi True. Kemudian lakukan ini:

>>> 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 hanya tersedia jika DEBUG adalah True. Itu adalah daftar dari dictionary untuk memanggil penjalanan. Setiap dictionary mempunyai berikut:

  • sql - Pernyataan SQL mentah

  • time - Lama pernyataan dijalankan, dalam detik.

connection.queries termasuk semua pernyataan SQL -- INSERTs, UPDATES, SELECT, dll. Setiap kali aplikasi anda mengenai basisdata, permintaan akan direkam.

Jika anda menggunakan multiple databases, anda dapat menggunakan antarmuka yang sama pada setiap anggota dictionary connections:

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

Jika anda butuh membersihkan daftar permintaan secara manual pada titik apapun dalam fungsi anda, panggil reset_queries(), seperti ini:

from django.db import reset_queries

reset_queries()

Bisakah saya menggunakan Django dengan basisdata yang sudah ada sebelumnya?

Ya. Lihat memadukan dengan warisan basisdata.

Jika Saya membuat perubahan pada model, bagaimana Saya memperbaharui basisdata?

Lihatlah pada dukungan Django untuk schema migrations.

Jika anda tidak keberatan membersihkan data, kegunaan manage.py proyek anda mempunyai pilihan flush untuk mengatur kembali basisdata ke keadaan nya dengan segera setelah migrate dijalankan.

Apakah model Django mendukung primary key banyak kolom?

Tidak. Hanya primary key kolom-tunggal yang didukung.

Tetapi ini bukanlah sebuah masalah dalam praktik, karena tidak ada yang menghentikan anda dari menambahkan batasan lain (menggunakan pilihan model unique_together atau membuat batasan langsung dalam basisdata anda), dan memaksa keunikan pada tingkatan itu. Primary key kolom-tunggal dibutuhkan untuk hal-hal seperti antarmuka admin untuk bekerja; yaitu anda butuh nilai tunggal untuk menentukan sebuah objek untuk menyunting atau menghapus.

Apakah Django mendukung basisdata NoSQL?

Basisdata NoSQL tidak secara resmi didukung oleh Django. Ada, bagaimanapun, sejumlah proyek sampingan dan turunan yang mengizinkan penggunaan NoSQL dalam Django.

Anda dapat melihat pada the wiki page yang mengobrolkan beberapa proyek.

Bagaimana Saya menambah pilihan khusus-basisdata ke pernyataan CREATE TABLE saya, seperti menentukan MyISAM sebagai jenis tabel?

Kami mencoba menghidnari menambahkan kasus khusus di kode Django untuk menampung semua pilihan basisdata-khusus seperti jenis tabel, dll. Jika anda ingin menggunakan salah satu pilihan ini, buat perpindahan dengan operasi RunSQL yang mengandung pernyataan ALTER TABLE yang melakukan apa anda ingin lakukan.

Sebagai contoh, jika anda menggunakan MySQL dan ingin tabel anda menggunakan jenis tabel MyISAM, gunakan SQL berikut:

ALTER TABLE myapp_mytable ENGINE=MyISAM;
Back to Top