Python 3 与 MySQL 5.6
主要简单说下Python 3.3搭配MySQL Community Server 5.6的使用。在Python 3系列和MySQL 5.0系列里面下面的代码应该都通用。(没有验证)
准备
python 3 这个在python的官方网站就能download. http://www.python.org/
MySQL Community Server 5.6 在MySQL的官网也能找到: http://dev.mysql.com/downloads/mysql/5.6.html
MySQL官方已经提供了支持Python 3.0的connector,地址: http://dev.mysql.com/downloads/connector/ (这里包含了MySQL对C, C++, Python, Java, .NET等语言的连接器)
简述
Python3访问MySQL 5.6过程和访问其他的数据没有太大的不同。都经历以下几个步骤:
- 建立连接。
- 建立游标cursor。
- 调用cursor的execute方法,以SQL语句和变量为参数,执行数据库操作。
- 返回结果。
- 关闭游标,关闭连接。
在操作之前,看下MySQL数据库里面的数据结构
读数据
从数据库读数据的基本操作。基本就是遵循上面的步骤。
eg1>>> import mysql
>>> from mysql import connector
>>> user = 'herbert'
>>> pwd = '851020'
>>> host = '127.0.0.1'
>>> db = 'world'
>>> cnx = mysql.connector.connect(user=user, password=pwd, host=host,
database=db)
>>> cursor = cnx.cursor()
>>> cursor.execute("SELECT * FROM CITY WHERE COUNTRYCODE = 'CHN';")
>>> cities = cursor.fetchall()
>>> cities
[(1890, 'Shanghai', 'CHN', 'Shanghai', 9696300), (1891, 'Peking', 'CHN', 'Peking', 7472000), (1892, 'Chongqing', 'CHN', 'Chongqing', 6351600), (1893, 'Tianjin', 'CHN', 'Tianjin', 5286800), ....
最后调用相应的方法关闭连接。里面关于Exception的处理方法和一般数据库连接相似,但是python里面每个数据库都定义了自己的DatabaseError。对于MySQL的DatabaseError是定义在mysql.connector模块中的。可以通过mysql.connector来查看和使用。
eg2>>> cursor.close()
True
>>> cnx.close()
>>> cnx
<mysql.connector.connection.MySQLConnection object at 0x00000000037FF160>
>>> cnx.is_connected()
False
>>>
写数据
如何更新数据库数据或者插入新数据。写入完成后,最好调用下连接器的commit()提交下数据(虽然它也会自动commit)
eg3>>> import mysql
>>> from mysql import connector
>>> user = 'herbert'
>>> pwd = '*****'
>>> host = '127.0.0.1'
>>> db = 'world'
>>> cnx = mysql.connector.connect(user=user, password=pwd, host=host,
database=db)
>>> cursor = cnx.cursor()
>>> cursor.execute("Update city Set Population = 9696500 Where ID = 1890 AND \
NAME = 'Shanghai';")
>>> cursor.close()
True
>>> cnx.commit()
>>> cnx.is_connected()
True
>>> cnx.close()
>>> cnx.is_connected()
False
>>>
更新后的数据库数据
参数化
在实际使用过程中,SQL语句的使用往往会带有参数,不是固定的,会接受用户的参数来返回用户想要的结果。同时这样做也可以防范一些SQL注入的危险。
在python的数据库模块中,每种数据库对应的参数处理形式往往是不同的。要根据具体的数据库的paramstyle选用相应的参数传入形式。有以下几种形式:
- qmark 问号类型。 eg. cur.execute(“… where name = ? and account = ?”, (symbol, account))
- numberic 数字类型。eg. cur.execute(“… where name = :0 and account = :1”, (symbol, account))
- named 命名类型。ORACLE数据库采用的形式。eg. cur.execute(“… where name = : symbol and account = :account”, {‘symbol’:value1, ‘account’: value2})
- format 格式代码。eg. cur.execute(“… where name = %s and account = %d”, (symbol, account))
- pyformat 扩展格式代码。MySQL采用的就是这种形式。eg. cur.execute(“… where name = %(name)s and account = %(account)d”, {‘symbol’:value1, ‘account’: value2})
paramstyle查看:
eg5>>> mysql.connector.paramstyle
'pyformat'
示例
eg4>>> import mysql
>>> from mysql import connector
>>> user = 'herbert'
>>> pwd = '851020'
>>> host = '127.0.0.1'
>>> db = 'world'
>>> country = 'CHN'
>>> cnx = mysql.connector.connect(user=user, password=pwd, host=host,
database=db)
>>> cursor = cnx.cursor()
>>> cursor.execute("SELECT * FROM CITY where CountryCode = %(country)s", {'country':country})
>>>
上面的示例同样也适用与更新和写入新数据操作。这样比字符串拼接有更好的安全性。
额外注意
- paramstyle在不同的数据库上的不同。
- cursor.execute方法在不同的数据库上适用略有不同。比如在ORACLE数据库上,还要先调用其cursor.prepare()方法,传入SQL语句。
- 对于数据库操作过程中的各种exception的处理,包括更新和写操作成功性的判断,进行commit或者rollback操作。
- 对于数据库读取的返回的数据的处理,可以使用namedtuple.但是还有更好的方法,在后面的文章进行专门讲述。
- 关于cursor的其他的方法的使用。python操作数据库最关键的还是cursor的各种方法调用。
Python 3 与 MySQL 5.6的更多相关文章
- Python中操作mysql的pymysql模块详解
Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...
- python——django使用mysql数据库(二)
上一篇中,我们已经讲述了如何初始化一个django数据库,这一章就来讲讲在实际的项目中如何使用我们初始化的数据库呢? 如还未进行初始化数据库操作,请参考python——django使用mysql数据库 ...
- python——django使用mysql数据库(一)
之前已经写过如何创建一个django项目,现在我们已经有了一个小骷髅,要想这个web工程变成一个有血有肉的人,我们还需要做很多操作.现在就先来介绍如何在django中使用mysql数据库. 前提:已经 ...
- Python 3 and MySQL
http://stackoverflow.com/questions/4960048/python-3-and-mysql up vote61down votefavorite 20 I am usi ...
- python & pandas链接mysql数据库
Python&pandas与mysql连接 1.python 与mysql 连接及操作,直接上代码,简单直接高效: import MySQLdb try: conn = MySQLdb.con ...
- 使用Python编程语言连接MySQL数据库代码
使用Python编程语言连接MySQL数据库代码,跟大家分享一下: 前几天我用python操作了mysql的数据库,发现非常的有趣,而且python操作mysql的方法非常的简单和快速,所以我把代码分 ...
- python针对于mysql的增删改查
无论是BS还是CS得项目,没有数据库是不行的. 本文是对python对mysql的操作的总结.适合有一定基础的开发者,最好是按部就班学习的人阅读.因为我认为人生不能永远都是从零开始,那简直就是灾难. ...
- Python 連接 MySQL
Python 連接 MySQL MySQL 是十分流行的開源資料庫系統,很多網站也是使用 MySQL 作為後台資料儲存,而 Python 要連接 MySQL 可以使用 MySQL 模組.MySQLdb ...
- Python中使用Mysql(安装篇)
准备工作 import MySQLdb Linux系统自带了Python,但并不是都有这个包,至少我每次拿到一台全新的服务器时候,都发现没有装这个包. 这个东西的下载地址是 http://source ...
- 第一篇:Win10系统搭建Python+Django+Nginx+MySQL 开发环境详解(完美版)
Win10+Python+Django+Nginx+MySQL 开发环境搭建详解 PaulTsao 说明:本文由作者原创,仅供内部参考学习与交流,转载引用请注明出处,用于商业目的请联系作者本人. Wi ...
随机推荐
- 点击jqGrid表格,弹出需要的表格的数据
首先,我们先定义一个函数,然后在JQuery里面直接引用就可以了, function GetJqGridRowValue(jgrid, code) { var KeyValue = "&qu ...
- iOS基于MBProgressHUD的二次封装,一行搞定,使用超简单
MBProgressHUD的使用,临时总结了几款最常用的使用场景: 1.提示消息 用法: [YJProgressHUD showMessage:@"显示文字,1s隐藏" inVie ...
- Session Sticky About Nginx
Nginx以前对session 保持支持不太好,主要采用ip_hash把同一来源的客户(同一C段的IP)固定指向后端的同一台机器,ip_hash有个缺点是不能实现很好的负载均衡:直到nginx的扩展模 ...
- 使用elasticsearch的关键技术点
前言 最近有一个项目用到了搜索引擎,这里记录下使用过程中遇到的一些问题和解决方案. 0.准备工作 1)安装elasticsearch 2)安装Marvel 3)安装head tips:在es的配置文件 ...
- linux编程之内存映射
一.概述 内存映射是在调用进程的虚拟地址空间创建一个新的内存映射. 内存映射分为2种: 1.文件映射 ...
- System.getProperty()引起的悲剧--您的主机中的软件中止了一个已建立的连接
我已无法形容此刻我的心情.. 本来是已经写好的netty5的demo程序,server和client之间创建tcp长连接的..然后随便传点数据的简单demo..然后今天试了一下tcp粘包的例子,用到了 ...
- web报表移动端如何进行移动设备绑定与撤销
场景需求描述 为了增强移动端的登录机制验证,保证数据的安全性,报表工具FineReport提供了移动设备绑定的功能,每个系统用户在使用移动端连接系统的时,需要管理员授权,将用户的移动设备与系统绑定起来 ...
- AI (Adobe Illustrator)详细用法(四)
本节主要是介绍和形状相关的操作. 一.外观面板的使用 熟悉外观面板的使用很重要. 1.新增描边 外观面板可以让我们增加多个描边. 点击“新增描边”,系统自动添加一个描边. 选中文字,新增描边,可以修改 ...
- 微信公众平台C# SDK:Senparc.Weixin.MP.dll
https://github.com/Senparc/WeiXinMPSDK [转] http://www.cnblogs.com/szw/archive/2013/01/13/senparc-wei ...
- 表单事件onsubmit与onreset
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...