转载来源:http://bbs.blueidea.com/archiver/tid-2813296.html
[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
分享到:
相关推荐
【Python操作数据库】 在计算机科学领域,Python是一种广泛使用的编程语言,其强大的功能之一就是能够与各种数据库进行交互。Python提供了多种库,如SQLite、MySQLdb、psycopg2(PostgreSQL)等,使得数据库操作变...
Python操作数据库详解 Python 是一种流行的高级编程语言,广泛应用于数据分析、人工智能、Web 开发等领域。随着数据时代的到来,数据库操作变得越来越重要。Python 提供了多种方式来操作数据库,本文将详细介绍 ...
第15章 使用Python操作数据库.pdf
Python操作数据库
python 操作数据库 mysql oracle cx_oracle to_sql 操作数据库 读取 插入 更新
python操作数据库,还有爬虫教程,你懂得好东西,有效期2个月速度....或者到达60分
Python操作数据库及Python实现mysql数据库连接池源代码。python编程中可以使用MySQLdb进行数据库的连接及诸如查询/插入/更新等操作,但是每次连接mysql数据库请求时,都是独立的去请求访问,相当浪费资源,而且访问...
在`Python操作数据库.md`文件中,可能会涵盖以下内容: 1. 安装`pymysql`库:使用`pip install pymysql`命令进行安装。 2. 创建数据库连接:通过`pymysql.connect()`函数创建连接,参数包括主机名、用户名、密码、...
在Python编程语言中,操作数据库是一项基础且重要的技能。Python提供了多种库来连接和操作不同的数据库系统,如MySQL、SQLite、PostgreSQL等。本手册将深入探讨如何利用Python进行数据库的交互,帮助读者掌握相关...
基于Python的MySQL基础和Python操作数据库
在IT领域,数据管理是核心任务之一,而使用编程语言如Python操作数据库则成为了一项必备技能。本文将深入探讨如何使用Python连接并操作Microsoft Access数据库,这一过程不仅涉及了基础的数据库连接,还包括了数据的...
本篇文章将详细探讨如何使用Python的pymysql库来实现对MySQL数据库的增、查、删、改(CRUD)操作。 首先,我们需要了解pymysql库。pymysql是Python连接MySQL数据库的一个库,它实现了Python DB-API v2.0规范,提供...
Python数据库操作函数,直接将数据库操作封装为函数,可直接调用。
Python是一种广泛使用的编程语言,尤其在数据处理和Web开发领域,其强大的库支持使得操作数据库变得非常便捷。本文将深入探讨Python如何与两种常见的数据库——SQLite和MySQL进行交互。 首先,我们来关注Python内置...
在本课程“Python操作三大主流数据库 实战网易新闻客户端”中,我们将深入学习如何使用Python与MySQL...通过学习,你不仅能熟练使用Python操作数据库,还能具备设计和管理数据库的能力,为你的IT职业生涯打下坚实基础。
Python作为一种高级编程语言,在数据库操作方面提供了多种途径。本文将详细介绍几种常见的使用Python进行数据库编程的方法,包括使用DAO(Data Access Objects)、Python DBAPI以及Python ODBC modules等。 #### 二...
Python 连接达梦数据库 Python 连接达梦数据库是指在 Python 编程语言中连接达梦数据库,以便在 Python 应用程序中使用达梦数据库。下面是 Python 连接达梦数据库的详细步骤和知识点: 检查 Python 是否安装 在...
复制代码 代码如下:#coding=utf-8__auther__ = ‘xianbao’import sqlite3# 打开数据库def opendata(): conn = sqlite3.connect(“mydb.db”) cur = conn.execute(“””create table if not exists tianjia(id ...
在本教程“Python操作三大主流数据库 实战网易新闻客户端”中,我们将深入学习如何使用Python语言与MySQL、PostgreSQL和SQLite这三大主流数据库进行交互,从而实现类似网易新闻客户端的数据管理功能。通过这个实战...
STPython的核心功能是通过调用神通数据库的ACI(Application Call Interface)接口来扩展Python的功能,使得开发者可以使用Python编写SQL语句来操作神通数据库。然而,为了正常运行STPython,除了Python标准库外,还...