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


Posted in Python onJuly 16, 2019

准备

软件 版本
Django 2.1.3
Python 3.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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
利用打码兔和超人打码自封装的打码类分享
Mar 16 Python
Python写的英文字符大小写转换代码示例
Mar 06 Python
python基础入门学习笔记(Python环境搭建)
Jan 13 Python
Python+django实现文件上传
Jan 17 Python
python使用logging模块发送邮件代码示例
Jan 18 Python
win7+Python3.5下scrapy的安装方法
Jul 31 Python
selenium+python实现自动化登录的方法
Sep 04 Python
Python GUI学习之登录系统界面篇
Aug 21 Python
Python接口开发实现步骤详解
Apr 26 Python
从0到1使用python开发一个半自动答题小程序的实现
May 12 Python
Python必须了解的35个关键词
Jul 16 Python
python爬虫调度器用法及实例代码
Nov 30 Python
Python二维码生成识别实例详解
Jul 16 #Python
python3.6+selenium实现操作Frame中的页面元素
Jul 16 #Python
Python Web版语音合成实例详解
Jul 16 #Python
windows下python虚拟环境virtualenv安装和使用详解
Jul 16 #Python
Pandas中DataFrame的分组/分割/合并的实现
Jul 16 #Python
Python的matplotlib绘图如何修改背景颜色的实现
Jul 16 #Python
python调用其他文件函数或类的示例
Jul 16 #Python
You might like
PHP 读取文件内容代码(txt,js等)
2009/12/06 PHP
浅析SVN常见问题及解决方法
2013/06/21 PHP
php解析json数据实例
2014/08/19 PHP
php实现通用的信用卡验证类
2015/03/24 PHP
php+html5+ajax实现上传图片的方法
2016/05/14 PHP
laravel5.6框架操作数据curd写法(查询构建器)实例分析
2020/01/26 PHP
CentOS7系统搭建LAMP及更新PHP版本操作详解
2020/03/26 PHP
ThinkPhP+Apache+PHPstorm整合框架流程图解
2020/11/23 PHP
(function($){...})(jQuery)的意思
2010/07/22 Javascript
javascript 仿QQ滑动菜单效果代码
2010/09/03 Javascript
关于Mozilla浏览器不支持innerText的解决办法
2011/01/01 Javascript
使用原生js封装webapp滑动效果(惯性滑动、滑动回弹)
2014/05/06 Javascript
关于javascript中dataset的问题小结
2015/11/16 Javascript
详解JavaScript节流函数中的Throttle
2016/07/16 Javascript
微信小程序  自定义创建详细介绍
2016/10/27 Javascript
详解AngularJs ui-router 路由的简单介绍
2017/04/26 Javascript
利用Javascript获取选择文本所在的句子详解
2017/12/03 Javascript
JavaScript实现图片放大镜效果
2019/06/27 Javascript
pygame学习笔记(5):游戏精灵
2015/04/15 Python
编写Python爬虫抓取暴走漫画上gif图片的实例分享
2016/04/20 Python
关于Django外键赋值问题详解
2017/08/13 Python
100行Python代码实现自动抢火车票(附源码)
2018/01/11 Python
Python基于jieba库进行简单分词及词云功能实现方法
2018/06/16 Python
python特性语法之遍历、公共方法、引用
2018/08/08 Python
python绘制热力图heatmap
2020/03/23 Python
python用win32gui遍历窗口并设置窗口位置的方法
2019/07/26 Python
对tensorflow中的strides参数使用详解
2020/01/04 Python
python 使用raw socket进行TCP SYN扫描实例
2020/05/05 Python
如何用Python 实现全连接神经网络(Multi-layer Perceptron)
2020/10/15 Python
市场安全管理制度
2014/01/26 职场文书
五五普法心得体会
2014/09/04 职场文书
给老婆的检讨书1000字
2015/01/01 职场文书
开平碉楼导游词
2015/02/06 职场文书
幼儿园五一劳动节活动总结
2015/02/09 职场文书
英语读书笔记
2015/07/02 职场文书
总结Python使用过程中的bug
2021/06/18 Python