`
xzh_endless
  • 浏览: 8644 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类

MySQLdb for Python使用指南/Python的数据库操作

阅读更多
原文 http://bbs.blueidea.com/viewthread.php?tid=2813296
有个地方说错了 后面改正了
-------------------------------------------------------


网站就是要和数据库进行交互,否则什么都不用做了...今天我们来看一个叫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. ... MySQLdb-module.html

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

[ 本帖最后由 planRED 于 2007-12-3 16:44 编辑 ]

------------------------------------------
其中:
fetchmany(self, size=None):接收size条返回结果行.如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据.
有误  
如果SIZE的值大于返回的结果行数,则会返回实际的结果行数
如果size默认值,则返回 cursor.arraysize条数据
分享到:
评论
1 楼 laitaogood 2009-11-14  
mark up

相关推荐

    python操作MySQL的MySQLdb模块

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

    python mysqldb

    MySQLdb是Python的一个适配器,它使得Python能够与MySQL数据库进行交互,执行SQL查询,处理数据库操作等任务。在给定的信息中,我们看到提到了"mysql-python",这其实指的是MySQLdb的旧命名方式,它与Python 2.6版本...

    Mysqldb-python

    例如,监控工具可能会用到MySQLdb-python来定期获取数据库的性能指标,如查询速度、内存使用情况、锁等待等,从而帮助优化数据库性能。 MySQLdb-python的核心特性包括: 1. **连接管理**:允许创建、管理和关闭到...

    Python技术数据库操作指南.docx

    首先,Python 提供了多种数据库操作模块,如 MySQLdb(用于 MySQL)、psycopg2(用于 PostgreSQL)、pymongo(用于 MongoDB)等,这些模块提供了与不同数据库系统进行连接和操作的接口。选择合适的模块取决于你正在...

    python操作mysql数据库.pdf

    Python DB-API是Python中...了解和掌握Python DB-API以及像MySQLdb这样的数据库接口,对于进行Python数据库开发来说至关重要。通过这些工具,开发者可以轻松地实现复杂的数据操作,从而提高工作效率并简化项目维护。

    python2.6集成mysqldb完整包,绝对可用。

    在下载的压缩包中,"认真看安装说明.txt"文件很可能是包含如何在Python 2.6环境中正确安装和使用mysqldb的指南。安装步骤通常包括以下几点: 1. **安装依赖**:在安装MySQLdb之前,确保你的系统上已经安装了MySQL...

    mysqldb64位

    MySQLdb是Python编程语言中用于连接MySQL数据库的一个重要库,主要为Python开发者提供了一种方便的方式来操作MySQL数据库。在64位系统上,你需要下载与系统兼容的版本,即"mysqldb64位",这通常是包含了适配Python...

    Python技术数据库驱动选用指南.docx

    ### Python技术数据库驱动选用指南 #### 一、MySQLdb - **特点**:MySQLdb是Python社区中最常用的一个与MySQL数据库交互的模块。它在Python 2.x版本中被广泛采用,具有高度稳定性和较快的速度。作为一个成熟的驱动...

    VCForPython275.zip

    MySQLdb是Python连接MySQL数据库的一个模块,但它需要特定的C编译环境才能正确构建。 描述中提到“安装MySQLdb时可能需要的环境Visual C++ 9.0”,这指的是Microsoft Visual C++ 2008 Redistributable Package,即...

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

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

    Python中文指南 v1.0.zip

    10. **数据库接口**:Python提供了多种数据库接口,如SQLite、MySQLdb、pymysql、psycopg2等,用于连接和操作数据库。了解如何使用这些库进行CRUD操作,是构建Web应用的基础。 11. **GUI编程**:Python的Tkinter库...

    python3程序开发指南第二版.rar

    对于数据库操作,Python3提供了多种数据库接口,如SQLite、MySQLdb、psycopg2等,本书可能会介绍如何使用这些接口进行数据库的连接、查询、插入、更新和删除操作。 最后,Python3在科学计算、数据分析和机器学习...

    Lukaszewski -- MySQL for Python -- 2010.pdf

    - **连接与操作**:详细讲解了如何使用Python中的库(如`MySQLdb`)来建立与MySQL数据库的连接,并执行基本的CRUD(创建、读取、更新、删除)操作。 - **高级功能**:进一步探讨了更高级的主题,如事务管理、存储...

    python学习源码和开发应用技术

    - **MySQLdb使用指南(Python数据库操作)**、**Python访问MySQL数据库**、**Python安装MySQLDb模块的种种问题及解决**:这三个资源共同构成了学习Python操作MySQL数据库的完整体系,不仅介绍了基本的操作方法,还解决...

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

    - **内容概述**:MySQLdb是Python操作MySQL数据库的常用库之一。 - **适用对象**:适合正在学习数据库操作的学习者。 - **学习价值**:通过实际项目加深对数据库操作的理解,提高数据库编程能力。 2. **Python ...

    Python技术参考大全

    在数据库编程方面,Python提供了多种数据库接口,如SQLite、MySQLdb和pymongo等,使得与数据库交互变得容易。对于Web开发,Python有Django和Flask这样的强大框架,用于快速构建Web应用。 最后,Python在数据分析和...

    MySQL-python-1.2.3.win-amd64-py2.7.exe

    Python MySQL模块是Python社区广泛使用的库,名为`pymysql`(原名`MySQLdb`),它实现了Python数据库API规范。此版本1.2.3的更新可能包括错误修复、性能优化或新功能的添加。同时,压缩包中包含了两个不同Python版本...

    Python库 | porter-db-0.0.6.tar.gz

    结合标签"python 数据库 开发语言 后端 database",我们可以推断porter-db是一个用于后端开发的Python数据库接口,它可能提供了连接、查询和操作数据库的能力。在Python中,常见的数据库库有SQLite、MySQLdb(用于...

Global site tag (gtag.js) - Google Analytics