本文详细讲述了Python使用MySQLdb for Python操作数据库的方法,分享给大家供大家参考。具体如下:

一般来说网站就是要和数据库进行交互,否则什么都不用做了。今天我们就来分析一个叫MySQLdb的库,使用这个用来和MySQL数据库进行交互.

大家可以从这里获得这个库:

http://sourceforge.net/projects/mysql-python

如果你不确定你的python环境里有没有这个库,那就打开python shell,输入 import MySQLdb,如果返回错误信息,那就表示你的机器上没有,赶紧去下载一个.我的机器是win xp,所以我下载了win环境下的exe那个,直接双击完成安装.

在介绍具体的操作前,我们先来说说一个程序怎么和数据库进行交互:

1.和数据库建立连接

2.执行sql语句,接收返回值

3.关闭数据库连接

使用MySQLdb也要遵循上面的几步.让我们一步步的进行.

一、引入MySQLdb库:

import MySQLdb

二、和数据库建立连接:

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() 回滚

三、执行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.

四、关闭数据库连接:

需要分别的关闭指针对象和连接对象.他们有名字相同的方法:

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 “的错误。对此,大家可以参考前面一篇文章Python中MYSQLdb出现乱码的解决方法。

希望本文所述对大家的Python程序设计有所帮助。

mysql db for python_Python使用MySQLdb for Python操作数据库教程相关推荐

  1. python操作数据库教程_python通用数据库操作工具 pydbclib|python基础教程|python入门|python教程...

    https://www.xin3721.com/eschool/pythonxin3721/ pydbclib是一个通用的python关系型数据库操作工具包,使用统一的接口操作各种关系型数据库(如 o ...

  2. python操作数据库教程_Python连接mysql数据库及简单增删改查操作示例代码

    1.安装pymysql 进入cmd,输入 pip install pymysql: 2.数据库建表 在数据库中,建立一个简单的表,如图: 3.简单操作 3.1查询操作 #coding=utf-8 #连 ...

  3. Python操作数据库之 MySQL

    Python操作数据库之MySQL 一.安装Python-MySQLdb模块 Python-MySQLdb是一个操作数据库的模块,Python 通过它对 mysql 数据实现各种操作. 如果要源码安装 ...

  4. Python操作数据库及Python实现mysql数据库连接池源代码

    简介 pymysql:纯Python实现的一个驱动.因为是纯Python编写的,因此执行效率不如MySQL-python.并且也因为是纯Python编写的,因此可以和Python代码无缝衔接. MyS ...

  5. Python 操作数据库(1)

    在关系数据库中,数据库表是一系列二维数组的集合,用来代表和储存数据对象之间的关系.它由纵向的列和横向的行组成,例如一个有关作者信息的名为 authors 的表中,每个列包含的是所有作者的某个特定类型的 ...

  6. mybatisplus 操作另一个数据库的数据_实例分析:python操作数据库项目

    本文根据一个项目实例,记录分享一下python将数据库的内容提取显示到程序界面的过程及相关设置,探索python操作数据库的用法.主要分享内容:1.显示数据库内容.2.修改数据库内容.3.表格控件指定 ...

  7. Python学习笔记(3):Python操作数据库

    安装MySQLdb 默认情况下Python中并没有安装MySQLdb,因此,在使用之前,我们要先安装MySQLdb. 安装步骤: 首先要下载MySQL-Python,下载地址是https://pypi ...

  8. python 操作数据库的常用SQL命令

    这俩天在学习PYTHON操作数据库的知识.其实基本SQL命令是与以前学习的MYSQL命令一致,只是增加了一些PYTHON语句. 1,安装pymysql,并导入. import pymysql 2,因为 ...

  9. Python操作数据库完成接口测试

    前言 数据库的操作在测试工作中也是经常使用的,通过一些一些工具来操作数据库的方法大家都应该了解,那么Python操作数据库的大家了解吗? 今天测试君通过本篇文章介绍下如何通过Python来操作mysq ...

  10. 五、使用Python操作数据库

    (六)使用Python操作数据 程序运行时,数据是在内存中.当程序终止时,通常需将数据保存在磁盘上.为了便于程序保存和读取数据,并能直接通过条件快速查询到指定数据,数据库(Database)这种专门用 ...

最新文章

  1. R可视化绘制t分布(t Distribution)
  2. python列表操作:追加元素到列表的代码
  3. 多层科目任意组合汇总报表的性能优化 (上)
  4. python中的优化器有哪些_Python中有哪些性能优化方法
  5. perl学习(1) 入门
  6. freemarker 从 spring boot execute jar可执行jar中访问模板文件
  7. tkinter的可视化拖拽工具_可视化越做越丑?这五个高级图表效果实现流程分享给你...
  8. 人是什么垃圾?AI识别功能用到垃圾分类上时 网友试了试“扫自己”
  9. 函数指针与回调函数、句柄
  10. UI设计字体素材|设计中字母间距指南
  11. 程序员面试金典——11.6矩阵元素查找
  12. H3C 初级综合实验
  13. 麦子学院6.1 神经网络算法(Nerual Networks)(上) 学习笔记
  14. dojo 框架实战笔记
  15. Netlogo入门(一)
  16. ​LeetCode刷题实战603:连续空余座位
  17. 1412202035-hpu-1003:C语言考试练习题_一元二次方程
  18. Python-量化投资(一)
  19. vue二级路由和重定向问题
  20. 【C#】错误:不可访问,因为它具有一定的保护级别

热门文章

  1. 计算机在现代设计技术中应用,计算机技术在现代建筑设计中的应用
  2. 实现一个简易的线程池。
  3. 背包问题2 (lintcode)
  4. 比特币那么火,今晚直播带你去「挖矿」!
  5. AV-TEST最新Windows 10平台最佳杀毒软件测试结果
  6. 那些年陪伴我的老师+我期待的师生关系
  7. iSCSI远程块存储配置实验
  8. Open×××多处理之-为什么不
  9. Model to Text工具Acceleo使用教程(七)——模板服务
  10. 去掉左边0_TiDB 4.0 在 VIPKID 的应用实践