Maison > développement back-end > Tutoriel Python > Comment changer la base de données par défaut en mysql dans Django (processus détaillé)

Comment changer la base de données par défaut en mysql dans Django (processus détaillé)

不言
Libérer: 2018-12-04 17:24:28
avant
3500 Les gens l'ont consulté

Le contenu de cet article explique comment changer la base de données par défaut en mysql dans Django (processus détaillé). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Django utilise la base de données sqlite3 par défaut. Aujourd'hui, j'ai étudié comment la remplacer par la base de données mysql commune.

Étant donné que le projet utilise python3 et que MySQLdb n'a pas de version prenant en charge python3, si vous utilisez la version python3.x, une erreur sera signalée lors de l'installation de MySQLdb par pip.

Plus tard, j'ai découvert grâce à Google que pymysql pouvait être utilisé pour remplacer MySQLdb

1 Ajoutez le code suivant au fichier __init__.py dans le répertoire racine du projet :

import pymysql
pymysql.install_as_MySQLdb()
Copier après la connexion

2 Utilisez mysqlclient Au lieu de MySQLdb, la méthode d'installation est :

pip install mysqlclient
Copier après la connexion

3 Modifiez la configuration de la base de données dans le projet settings.py en :

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'test',
        'USER': 'username',
        'PASSWORD': 'passwd',
        'HOST': 'localhost',
        'PORT': '3306'
    }
}
Copier après la connexion

4 Enfin, via python Commande manage.py migrate, Django créera automatiquement la table correspondante dans la base de données

Operations to perform:
  Apply all migrations: admin, auth, contenttypes, polls, sessions
Running migrations:
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying admin.0002_logentry_remove_auto_add... OK
  Applying admin.0003_logentry_add_action_flag_choices... OK
  Applying contenttypes.0002_remove_content_type_name... OK
  Applying auth.0002_alter_permission_name_max_length... OK
  Applying auth.0003_alter_user_email_max_length... OK
  Applying auth.0004_alter_user_username_opts... OK
  Applying auth.0005_alter_user_last_login_null... OK
  Applying auth.0006_require_contenttypes_0002... OK
  Applying auth.0007_alter_validators_add_error_messages... OK
  Applying auth.0008_alter_user_username_max_length... OK
  Applying auth.0009_alter_user_last_name_max_length... OK
  Applying polls.0001_initial... OK
  Applying sessions.0001_initial... OK
Copier après la connexion

5 Lors de la création de l'utilisateur administrateur, j'ai rencontré l'erreur suivante

python manage.py createsuperuser
Superuser creation skipped due to not running in a TTY. You can run `manage.py createsuperuser` in your project to create one manually.
Copier après la connexion

Après vérification, il C'est parce que git a été utilisé pour exécuter la commande, le passage à la ligne de commande fournie avec Windows peut résoudre ce problème !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:segmentfault.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal