Python Django切换MySQL数据库实例详解

作者:小柒 时间:2024-01-21 02:02:47 

准备

软件版本
Django2.1.3
Python3.7.1

默认使用的是sqlite3


DATABASES = {
  'default': {
    'ENGINE': 'django.db.backends.sqlite3',
    'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
  }
}

切换为MySql:


# settings.py
DATABASES = {
 'default': {
   'ENGINE': 'django.db.backends.mysql',
   'NAME': 'book',
   'USER': 'root',
   'PASSWORD': '123456',
   'HOST': '127.0.0.1',
   'POST': '3306',
 }
}

实现步骤

我们使用Django 来操作MySQL,实际上底层还是通过Python来操作的。因此我们想要用Django来操作MySQL,首先还是需要安装一个驱动程序。在Python3中,驱动程序有多种选择。比如有pymysql以及mysqlclient等。

常见的Mysql驱动介绍:

  • MySQL-python:也就是MySQLdb。是对C语言操作MySQL数据库的一个简单封装。遵循了Python DB API v2。但是只支持Python2,目前还不支持Python3。

  • mysqlclient:是MySQL-python的另外一个分支。支持Python3并且修复了一些bug。

  • pymysql:纯Python实现的一个驱动。因为是纯Python编写的,因此执行效率不如MySQL-python。并且也因为是纯Python编写的,因此可以和Python代码无缝衔接。

  • MySQL Connector/Python:MySQL官方推出的使用纯Python连接MySQL的驱动。因为是纯Python开发的。效率不高。

mysqlclient安装

基于目前的环境以及版本来说,直接运行 pip install mysqlclient 是会报错的,具体错误,自己执行以下就知道了。

解决办法:

去 https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysqlclient 下载指定文件,我用的是python3.7,win环境是64位,所以下载了mysqlclient-1.3.13-cp37-cp37m-win_amd64.whl。

然后执行:


pip3 install mysqlclient-1.3.13-cp37-cp37m-win_amd64.whl

如果出现以下说明安装成功:


Installing collected packages: mysqlclient
Successfully installed mysqlclient-1.3.13

迁移数据库

Django中通过以下命令来迁移数据库,在每次创建Model时,执行该命令,在数据库中生成对应的表:


python manage.py makemigrations
python manage.py migrate

来源:https://blog.52itstyle.vip/archives/3671/

标签:python,django,切换,mysql,数据库
0
投稿

猜你喜欢

  • 中国移动G3笔记本全Flash 网站

    2009-04-27 12:51:00
  • Python实现爬取亚马逊数据并打印出Excel文件操作示例

    2021-09-10 05:10:36
  • 良好的css代码注释

    2008-07-01 13:02:00
  • 浏览器根据什么来判定脚本失控?[译]

    2009-02-20 13:36:00
  • 使用python创建Excel工作簿及工作表过程图解

    2021-10-05 03:57:34
  • python实现简单的井字棋游戏(gui界面)

    2023-03-06 23:16:01
  • Python中使用sklearn进行特征降维的方法

    2021-09-20 06:23:50
  • window.onload和$(function(){})的区别介绍

    2024-06-07 15:51:44
  • javascript+HTML5 canvas绘制时钟功能示例

    2024-05-05 09:14:01
  • SQL数据库优化大总结之百万级数据库优化方案

    2024-01-16 09:42:10
  • Perl使用chdir的实例代码

    2023-02-13 19:33:56
  • 使用Python的PIL模块来进行图片对比

    2022-04-28 19:18:36
  • Mysql查询以某"字符串"开头的查询方式

    2024-01-24 21:05:19
  • python如何重载模块实例解析

    2021-10-13 03:47:56
  • sqlserver数据库大型应用解决方案经验总结

    2024-01-26 13:38:52
  • JSP实现用户登录、注册和退出功能

    2024-03-18 10:13:43
  • Python实现线性插值和三次样条插值的示例代码

    2023-12-04 19:19:42
  • JavaScript实现鼠标经过显示下拉框

    2024-04-28 09:52:36
  • Python数据类型转换实现方法

    2022-06-04 22:58:39
  • 选择MySQL数据库进行连接的简单示例

    2024-01-24 02:35:50
  • asp之家 网络编程 m.aspxhome.com