用 Python 连接 MySQL 的几种方式详解


Posted in Python onApril 04, 2018

尽管很多 NoSQL 数据库近几年大放异彩,但是像 MySQL 这样的关系型数据库依然是互联网的主流数据库之一,每个学 Python 的都有必要学好一门数据库,不管你是做数据分析,还是网络爬虫,Web 开发、亦或是机器学习,你都离不开要和数据库打交道,而 MySQL 又是最流行的一种数据库,这篇文章介绍 Python 操作 MySQL 的几种方式,你可以在实际开发过程中根据实际情况合理选择。

1、MySQL-python

MySQL-python 又叫 MySQLdb,是 Python 连接 MySQL 最流行的一个驱动,很多框架都也是基于此库进行开发,遗憾的是它只支持 Python2.x,而且安装的时候有很多前置条件,因为它是基于C开发的库,在 Windows 平台安装非常不友好,经常出现失败的情况,现在基本不推荐使用,取代的是它的衍生版本。

# 前置条件
sudo apt-get install python-dev libmysqlclient-dev # Ubuntu
sudo yum install python-devel mysql-devel # Red Hat / CentOS
# 安装
pip install MySQL-python

Windows 直接通过下载 exe 文件安装,公众号回复「win」获取下载链接

#!/usr/bin/python
import MySQLdb
db = MySQLdb.connect(
   host="localhost",  # 主机名
   user="john",     # 用户名
   passwd="megajonhy", # 密码
   db="jonhydb")    # 数据库名称
# 查询前,必须先获取游标
cur = db.cursor()
# 执行的都是原生SQL语句
cur.execute("SELECT * FROM YOUR_TABLE_NAME")
for row in cur.fetchall():
  print(row[0])
db.close()

2、mysqlclient

由于 MySQL-python 年久失修,后来出现了它的 Fork 版本 mysqlclient,完全兼容 MySQLdb,同时支持 Python3.x,是 Django ORM的依赖工具,如果你想使用原生 SQL 来操作数据库,那么推荐此驱动。安装方式和 MySQLdb 是一样的,Windows 可以在 https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysqlclient 网站找到 对应版本的 whl 包下载安装。

用 Python 连接 MySQL 的几种方式详解

# Windows安装
pip install some-package.whl
# linux 前置条件
sudo apt-get install python3-dev # debian / Ubuntu
sudo yum install python3-devel # Red Hat / CentOS
brew install mysql-connector-c # macOS (Homebrew)
pip install mysqlclient

3、PyMySQL

PyMySQL 是纯 Python 实现的驱动,速度上比不上 MySQLdb,最大的特点可能就是它的安装方式没那么繁琐,同时也兼容 MySQL-python

pip install PyMySQL
# 为了兼容mysqldb,只需要加入
pymysql.install_as_MySQLdb()

一个例子

import pymysql
conn = pymysql.connect(host='127.0.0.1', user='root', passwd="xxx", db='mysql')
cur = conn.cursor()
cur.execute("SELECT Host,User FROM user")
for r in cur:
  print(r)
cur.close()
conn.close()

4、peewee

写原生 SQL 的过程非常繁琐,代码重复,没有面向对象思维,继而诞生了很多封装 wrapper 包和 ORM 框架,ORM 是 Python 对象与数据库关系表的一种映射关系,有了 ORM 你不再需要写 SQL 语句。提高了写代码的速度,同时兼容多种数据库系统,如sqlite, mysql、postgresql,付出的代价可能就是性能上的一些损失。如果你对 Django 自带的 ORM 熟悉的话,那么 peewee的学习成本几乎为零。它是 Python 中是最流行的 ORM 框架。

pip install peewee

一个例子

import peewee
from peewee import *
db = MySQLDatabase('jonhydb', user='john', passwd='megajonhy')
class Book(peewee.Model):
  author = peewee.CharField()
  title = peewee.TextField()
  class Meta:
    database = db
Book.create_table()
book = Book(author="me", title='Peewee is cool')
book.save()
for book in Book.filter(author="me"):
  print(book.title)

官方文档:http://docs.peewee-orm.com/en/latest/peewee/installation.html

5、SQLAlchemy

如果想找一种既支持原生 SQL,又支持 ORM 的工具,那么 SQLAlchemy 是最好的选择,它非常接近 Java 中的 Hibernate 框架。

from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy_declarative import Address, Base, Person
class Address(Base):
  __tablename__ = 'address'
  id = Column(Integer, primary_key=True)
  street_name = Column(String(250))
engine = create_engine('sqlite:///sqlalchemy_example.db')
Base.metadata.bind = engine
DBSession = sessionmaker(bind=engine)
session = DBSession()
# Insert a Person in the person table
new_person = Person(name='new person')
session.add(new_person)
session.commit()

现在差不多搞明白了这几种数据库驱动的优劣,接下来你就可以选择其中的一个进行系统的学习再把它应用到项目中去了,祝你学习开心,不懂的可以咨询我哈。

总结

以上所述是小编给大家介绍的用 Python 连接 MySQL 的几种姿势详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Python 相关文章推荐
pygame学习笔记(5):游戏精灵
Apr 15 Python
网站渗透常用Python小脚本查询同ip网站
May 08 Python
Python爬虫基础之XPath语法与lxml库的用法详解
Sep 13 Python
在PyTorch中Tensor的查找和筛选例子
Aug 18 Python
python sklearn常用分类算法模型的调用
Oct 16 Python
Python实现i人事自动打卡的示例代码
Jan 09 Python
pytorch实现特殊的Module--Sqeuential三种写法
Jan 15 Python
python range实例用法分享
Feb 06 Python
Django框架安装及项目创建过程解析
Sep 14 Python
python实现视频压缩功能
Dec 18 Python
Django和Ueditor自定义存储上传文件的文件名
Feb 25 Python
Python实现socket库网络通信套接字
Jun 04 Python
Python基于辗转相除法求解最大公约数的方法示例
Apr 04 #Python
对numpy中数组元素的统一赋值实例
Apr 04 #Python
Python 元类实例解析
Apr 04 #Python
对numpy 数组和矩阵的乘法的进一步理解
Apr 04 #Python
Numpy数组的保存与读取方法
Apr 04 #Python
基于Python Numpy的数组array和矩阵matrix详解
Apr 04 #Python
Python基于更相减损术实现求解最大公约数的方法
Apr 04 #Python
You might like
为了这两部电子管收音机,买了6套全新电子管和10粒刻度盘灯泡
2021/03/02 无线电
php 空格,换行,跳格使用说明
2009/12/18 PHP
php函数之子字符串替换 str_replace
2011/03/23 PHP
通过php删除xml文档内容的方法
2015/01/23 PHP
PHP微信开发之微信录音临时转永久存储
2018/01/26 PHP
PHP+Ajax实现上传文件进度条动态显示进度功能
2018/06/04 PHP
jquery绑定事件不生效的解决方法
2014/02/11 Javascript
js离开或刷新页面检测(且兼容FF,IE,Chrome)
2014/03/05 Javascript
js动态添加表格数据使用insertRow和insertCell实现
2014/05/22 Javascript
js实现透明度渐变效果的方法
2015/04/10 Javascript
js实现Select头像选择实时预览代码
2015/08/17 Javascript
深入理解JavaScript中的浮点数
2016/05/18 Javascript
通过jsonp获取json数据实现AJAX跨域请求
2017/01/22 Javascript
微信小程序实现分享到朋友圈功能
2018/07/19 Javascript
关于引入vue.js 文件的知识点总结
2020/01/28 Javascript
[00:32]2018DOTA2亚洲邀请赛Mineski出场
2018/04/04 DOTA
Django URL传递参数的方法总结
2016/08/28 Python
Python实现模拟分割大文件及多线程处理的方法
2017/10/10 Python
python通过opencv实现批量剪切图片
2017/11/13 Python
python如何实现int函数的方法示例
2018/02/19 Python
解决python删除文件的权限错误问题
2018/04/24 Python
Django Web开发中django-debug-toolbar的配置以及使用
2018/05/06 Python
numpy:找到指定元素的索引示例
2019/11/26 Python
Windows 下更改 jupyterlab 默认启动位置的教程详解
2020/05/18 Python
python如何删除文件、目录
2020/06/23 Python
关于python3.9安装wordcloud出错的问题及解决办法
2020/11/02 Python
2020年10款优秀的Python第三方库,看看有你中意的吗?
2021/01/12 Python
美国第一个网上卖鞋零售商:OnlineShoes.com
2017/09/24 全球购物
洲际酒店集团美国官网:IHG美国
2017/11/16 全球购物
博士生入学考试推荐信
2013/11/17 职场文书
会议接待欢迎词
2014/01/12 职场文书
施工安全承诺书
2014/05/22 职场文书
2014年信访工作总结
2014/11/17 职场文书
2016年小学生寒假总结
2015/10/10 职场文书
学校2016年圣诞节活动总结
2016/03/31 职场文书
什么是clearfix (一文搞清楚css清除浮动clearfix)
2023/05/21 HTML / CSS