`

MySQLdb for Python

阅读更多
[Python]MySQLdb for Python使用指南/Python的数据库操作
网站就是要和数据库进行交互,否则什么都不用做了...今天我们来看一个叫MySQLdb的库,这个用来和MySQL数据库进行交互.
可以从这里获得这个库
http://sourceforge.net/projects/mysql-python
如果你不确定你的python环境里有没有这个库,那就打开python shell,输入 import MySQLdb,如果返回错误信息,那就表示你的机器上没有,赶紧去下载一个.我的机器是win xp,所以我下载了win环境下的exe那个,直接双击完成安装.

在介绍具体的操作前,先花点时间来说说一个程序怎么和数据库进行交互
1.和数据库建立连接
2.执行sql语句,接收返回值
3.关闭数据库连接
使用MySQLdb也要遵循上面的几步.让我们一步步的进行.

0.引入MySQLdb库
import MySQLdb

1.和数据库建立连接
conn=MySQLdb.connect(host="localhost",user="root",passwd="sa",db="mytable")
提供的connect方法用来和数据库建立连接,接收数个参数,返回连接对象.

比较常用的参数包括
host:数据库主机名.默认是用本地主机.
user:数据库登陆名.默认是当前用户.
passwd:数据库登陆的秘密.默认为空.
db:要使用的数据库名.没有默认值.
port:MySQL服务使用的TCP端口.默认是3306.
更多关于参数的信息可以查这里
http://mysql-python.sourceforge.net/MySQLdb.html

然后,这个连接对象也提供了对事务操作的支持,标准的方法
commit() 提交
rollback() 回滚

2.执行sql语句和接收返回值
cursor=conn.cursor()
n=cursor.execute(sql,param)
首先,我们用使用连接对象获得一个cursor对象,接下来,我们会使用cursor提供的方法来进行工作.这些方法包括两大类:1.执行命令,2.接收返回值

cursor用来执行命令的方法:
callproc(self, procname, args):用来执行存储过程,接收的参数为存储过程名和参数列表,返回值为受影响的行数
execute(self, query, args):执行单条sql语句,接收的参数为sql语句本身和使用的参数列表,返回值为受影响的行数
executemany(self, query, args):执行单挑sql语句,但是重复执行参数列表里的参数,返回值为受影响的行数
nextset(self):移动到下一个结果集

cursor用来接收返回值的方法:
fetchall(self):接收全部的返回结果行.
fetchmany(self, size=None):接收size条返回结果行.如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据.
fetchone(self):返回一条结果行.
scroll(self, value, mode='relative'):移动指针到某一行.如果mode='relative',则表示从当前所在行移动value条,如果mode='absolute',则表示从结果集的第一行移动value条.

下面的代码是一个完整的例子.
#使用sql语句,这里要接收的参数都用%s占位符.要注意的是,无论你要插入的数据是什么类型,占位符永远都要用%s
sql="insert into cdinfo values(%s,%s,%s,%s,%s)"
#param应该为tuple或者list
param=(title,singer,imgurl,url,alpha)
#执行,如果成功,n的值为1
n=cursor.execute(sql,param)

#再来执行一个查询的操作
cursor.execute("select * from cdinfo")
#我们使用了fetchall这个方法.这样,cds里保存的将会是查询返回的全部结果.每条结果都是一个tuple类型的数据,这些tuple组成了一个tuple
cds=cursor.fetchall()
#因为是tuple,所以可以这样使用结果集
print cds[0][3]
#或者直接显示出来,看看结果集的真实样子
print cds

#如果需要批量的插入数据,就这样做
sql="insert into cdinfo values(0,%s,%s,%s,%s,%s)"
#每个值的集合为一个tuple,整个参数集组成一个tuple,或者list
param=((title,singer,imgurl,url,alpha),(title2,singer2,imgurl2,url2,alpha2))
#使用executemany方法来批量的插入数据.这真是一个很酷的方法!
n=cursor.executemany(sql,param)

需要注意的是(或者说是我感到奇怪的是),在执行完插入或删除或修改操作后,需要调用一下conn.commit()方法进行提交.这样,数据才会真正保存在数据库中.我不清楚是否是我的mysql设置问题,总之,今天我在一开始使用的时候,如果不用commit,那数据就不会保留在数据库中,但是,数据确实在数据库呆过.因为自动编号进行了累积,而且返回的受影响的行数并不为0.

3.关闭数据库连接
需要分别的关闭指针对象和连接对象.他们有名字相同的方法
cursor.close()
conn.close()

三步完成,基本的数据库操作就是这样了.下面是两个有用的连接
MySQLdb用户指南: http://mysql-python.sourceforge.net/MySQLdb.html
MySQLdb文档: http://mysql-python.sourceforge.net/MySQLdb-1.2.2/public/MySQLdb-module.html

现在让我头痛的问题是字符的编码问题,在插入中文的时候,总会乱码.我尝试着改变编码,又会出现"Data too long for column "的错误.我在网上搜到了一些相关的文章,但现在还没有整理.这个需要暂时的放一下了,先把lantern扎好再说.当然,如果有大侠知道详细的解决办法,请不吝赐教
分享到:
评论

相关推荐

    mysqldb for python2--win64

    MySQLdb for Python2是Python 2.x版本中用于与MySQL数据库进行交互的库,它为Python程序员提供了一种方便的方式来操作MySQL数据。标题中的“mysqldb for python2--win64”指的是这个库的Windows 64位版本,特别针对...

    mysqldb for python2.5 in windows

    windows mysqldb for python2.5 in windows

    MySQLdb for Python 2.6 (Windows编译版)

    MySQLdb for Python 2.6 我自己在XP下用VC++ 2008 Express编译的 需要的就下载吧!

    MySQLdb for python2 7 and win7 64bit

    MySQLdb for python2 7 and win7 64bit 我装了 没问题

    Python使用MySQLdb for Python操作数据库教程

    本文详细讲述了Python使用MySQLdb for Python操作数据库的方法,分享给大家供大家参考。具体如下: 一般来说网站就是要和数据库进行交互,否则什么都不用做了。今天我们就来分析一个叫MySQLdb的库,使用这个用来和...

    MySQLdb-python

    MySQLdb-python是Python编程语言与MySQL数据库之间的一个接口库,它允许Python开发者使用标准的DB-API(Python Database API Specification v2.0)来操作MySQL数据库。这个资源包含了针对不同操作系统和Python版本的...

    Mysqldb-Python3.*

    在Python编程中,Mysqldb是用于连接MySQL数据库的一个库,特别适用于Python 2.x版本。然而,对于Python 3.x,Mysqldb并未直接支持,这导致了开发者在尝试连接Python 3.x与MySQL 5.x时可能会遇到问题。在Python 3.x...

    python2.6-MySQLdb

    python2.6-MySQLdb,包括python2.6安装包、MySQLdb for python2.6安装包、MySQLdb使用配置,为想学习Python操作mysql数据库的同学提供了极大的方便。。。

    MySQLdb 1.2.3 for Python 2.7 (Windows)

    MySQLdb 1.2.3 for Python 2.7 (Windows)

    MySQL-python

    标签“mysqldb for python”表明这个库是专为Python设计的MySQL驱动程序。使用MySQL-python库,开发者可以方便地集成MySQL数据库到Python应用程序中,进行数据的存取、更新和删除等操作。 在压缩包文件"MySQL-...

    Mysqldb-python

    MySQLdb-python是一个Python接口库,它为Python编程语言提供了与MySQL数据库交互的功能。这个库是基于DB-API 2.0规范(PEP 249)设计的,使得Python开发者可以方便地执行SQL语句、管理数据库事务以及处理MySQL相关的...

    VCForPython27和windows 系统下python 2.7 的mysql驱动

    "VCForPython27"是Microsoft为Python 2.7提供的Visual C++运行库,它是安装某些Python扩展模块,如MySQL驱动(通常称为`pymysql`或`MySQLdb`)所必需的,因为这些模块可能依赖于C编译的库。`VCForPython27`解决了...

    Win环境下配置Python3 MySQLdb

    在Windows环境下配置Python3与MySQLdb的连接是一个常见的任务,特别是在进行数据分析或Web开发时。MySQLdb是Python的一个数据库适配器,它允许Python程序与MySQL数据库进行交互。但是,Python 3.x版本中不再直接支持...

    MySQLdb for windows

    包含4个文件: MySQL-python-1.2.3.win32-py2.7 MySQL-python-1.2.2.win-amd64-py2.6 MySQL-python-1.2.2.win32-py2.6 MySQL-python-1.2.3.win-amd64-py2.7

    【Python典藏】80个Python经典资料汇总

    - `MySQLdb for python2.7 win`:Python连接MySQL数据库的驱动,对于做数据处理的开发者很有价值。 - `wxPython实战`:介绍如何使用wxPython库构建图形用户界面,适用于桌面应用开发。 这些资料涵盖了Python语法...

    80个Python经典资料(教程+源码+工具)汇总——下载目录

    1. **MySQLdb for python 2.7 win** - **内容概述**:MySQLdb是Python操作MySQL数据库的常用库之一。 - **适用对象**:适合正在学习数据库操作的学习者。 - **学习价值**:通过实际项目加深对数据库操作的理解,...

    天兔数据库监控系统

    然后,安装Python基础模块,包括MySQLdb for python,用于连接和操作MySQL数据库。 在安装过程中,可能会出现一些错误,例如,error: command 'gcc' failed with exit status 1错误,可以通过安装python-devel和...

    MySQLdb 1.2.4b4 documentation

    MySQLdb是Python编程语言中用于连接MySQL数据库的一个重要模块,它为Python程序员提供了一个符合Python标准库DB-API接口的MySQL驱动。MySQLdb 1.2.4b4是该模块的一个版本,它提供了稳定性和兼容性的改进,使得Python...

    python操作MySQL的MySQLdb模块

    Python中的MySQLdb模块是连接和操作MySQL数据库的一个重要工具,尤其在Python 2.x版本中广泛使用。这个模块是Python的DB-API(数据库应用编程接口)的一个实现,它提供了与MySQL交互的一系列函数和类。下面我们将...

Global site tag (gtag.js) - Google Analytics