先举一例:

一个 Python代码实例:

# -*- coding: utf-8 -*-     

#mysqldb    

import time, MySQLdb    

   

#连接    

conn=MySQLdb.connect(host="localhost",user="root",passwd="",db="test",charset="utf8")  

cursor = conn.cursor()    

   

#写入    

sql = "insert into user(name,created) values(%s,%s)"   

param = ("aaa",int(time.time()))    

n = cursor.execute(sql,param)    

print n    

   

#更新    

sql = "update user set name=%s where id=3"   

param = ("bbb")    

n = cursor.execute(sql,param)    

print n    

   

#查询    

n = cursor.execute("select * from user")    

for row in cursor.fetchall():    

    for r in row:    

        print r    

   

#删除    

sql = "delete from user where name=%s"   

param =("aaa")    

n = cursor.execute(sql,param)    

print n    

cursor.close()    

   

#关闭    

conn.close()

1.引入MySQLdb库

import MySQLdb 





2.和数据库建立连接 

conn=MySQLdb.connect(host="localhost",user="root",passwd="sa",db="mytable",charset="utf8") 

提供的connect方法用来和数据库建立连接,接收数个参数,返回连接对象. 





比较常用的参数包括 

host:数据库主机名.默认是用本地主机. 

user:数据库登陆名.默认是当前用户. 

passwd:数据库登陆的秘密.默认为空. 

db:要使用的数据库名.没有默认值. 

port:MySQL服务使用的TCP端口.默认是3306.

charset:数据库编码.

更多关于参数的信息可以查这里 

http://mysql-python.sourceforge.net/MySQLdb.html 





然后,这个连接对象也提供了对事务操作的支持,标准的方法 

commit() 提交 

rollback() 回滚 





3.执行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) 





4.关闭数据库连接 

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

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

5 编码(防止乱码)

需要注意的点:

    1 Python文件设置编码 utf-8 (文件前面加上 #encoding=utf-8)

    2 MySQL数据库charset=utf-8 

    3 Python连接MySQL是加上参数 charset=utf8 

    4 设置Python的默认编码为 utf-8 (sys.setdefaultencoding(utf-8)

#encoding=utf-8 

 import sys 

 import MySQLdb 

  

 reload(sys) 

 sys.setdefaultencoding('utf-8') 

  

 db=MySQLdb.connect(user='root',charset='utf8') 

注:MySQL的配置文件设置也必须配置成utf8





设置 MySQL 的 my.cnf 文件,在 [client]/[mysqld]部分都设置默认的字符集(通常在/etc/mysql/my.cnf): 

[client]

default-character-set = utf8

[mysqld]

default-character-set = utf8

python中MySQLdb的使用的更多相关文章

  1. python中MySQLdb模块用法实例

    篇文章主要介绍了python中MySQLdb模块用法,以实例形式详细讲述了MySQLdb模块针对MySQL数据库的各种常见操作方法,非常具有实用价值,需要的朋友可以参考下 本文实例讲述了python中 ...

  2. Python中MySQLdb模块的安装

    安装 MySQLdb是Python语言访问mysql数据库的一个模块,如果你不确定自己的Python环境中是否已经安装了这个模块,可以打开Python shell,输入import MySQLdb,如 ...

  3. python中mysqldb的用法

    1.引入MySQLdb库 import MySQLdb 2.和数据库建立连接 conn=MySQLdb.connect(host="localhost",user="ro ...

  4. Python中MySQLdb的事务处理

    今天写了个tool,目的是把csv中的数据插入到数据库中去.其中有一部分,是需要分别向两张表中插入两条数据,如果第二张表中的数据已经存在,那么第一张表中的数据也不需要插入. 然后通过百度查找发现,其实 ...

  5. python安装MySQLdb:在windows下或linux下(以及eclipse中pydev使用msqldb的配置方法)

    写的非常好,可以解决问题: windows下:http://blog.csdn.net/wklken/article/details/7253245 linux下:http://blog.csdn.n ...

  6. python MySQLdb用法,python中cursor操作数据库(转)

    数据库连接 连接数据库前,请先确认以下事项: 您已经创建了数据库 TESTDB. 在TESTDB数据库中您已经创建了表 EMPLOYEE EMPLOYEE表字段为 FIRST_NAME, LAST_N ...

  7. Python中操作mysql的pymysql模块详解

    Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...

  8. Python的MySQLdb模块安装

    MySQL-python-1.2.1.tar.gz  下载地址:https://pan.baidu.com/s/1kVfH84v 然后解压,打开README(这个其实没有什么鸟用) 里面有安装过程: ...

  9. CentOS 下安装python 之MySQLdb

    yum -y install mysql-devwget http://downloads.sourceforge.net/project/mysql-python/mysql-python-test ...

随机推荐

  1. 华科机考:IP地址

    时间限制:1秒  空间限制:32768K 题目描述 输入一个ip地址串,判断是否合法. 输入描述: 输入的第一行包括一个整数n(1<=n<=500),代表下面会出现的IP地址的个数. 接下 ...

  2. 如何在 vmware esxi 中开放 VNC功能及端口实现远程管理 完整篇

    VMWare esxi中开放 VNC功能及端口实现远程管理 完整篇 在多个论坛上看了相关文章,总的写得不完整.现将各方资源整编写完整版.详文如下! (图片来自51CTO) 步骤1. 修改ESXi主机的 ...

  3. 虚拟机搭建Zookeeper服务器集群完整笔记

    虚拟机搭建Zookeeper服务器集群完整笔记 本笔记主要记录自己搭建Zookeeper服务器的全过程,默认已经安装部署好Centos7. 一.虚拟机下Centos无法联网解决方案 1.首先调整虚拟机 ...

  4. …… are only available on JDK 1.5 and higher 错误(spring 的jdk版本检测在jdk 8下的修订)

    正常方法 用更高的版本,因为spring向下兼容. 我公司需求的方法(真 迟早跑路) 1.在项目中创建一个package为org.springframework.core 2.在该package下面新 ...

  5. Errors running builder 'DeploymentBuilder' on project '工程名'

    打开myEclipse就会报 Errors running builder 'DeploymentBuilder' on project '工程名' xxxNullpointException 的错误 ...

  6. 浅谈JS变量声明和函数声明提升

    先来两个问题 很多时候,在直觉上,我们都会认为JS代码在执行时都是自上而下一行一行执行的,但是实际上,有一种情况会导致这个假设是错误的. a = 2; var a; console.log(a); 按 ...

  7. Dapper连接与事务的简单封装

    增删改查方面,已经有Dapper.Extension这么强大的工具了,我也实在没啥好写的,就随手写了个看起来比较优雅的连接与事务的封装.在之后使用Dapper.Extension类库时,完全可以照搬进 ...

  8. 安卓 新版本 获取wifi状态网络是否可用等

    写下这篇文章目的:当我学习的和百度看看如何获取网络状态 发现都是一些比较老的方法 API23已结过时 所以在此写下记录 ,我不明白国内为什么那么少 那么我们来看看旧方法 package com.che ...

  9. Java学习之参数传递详解

    Java中的参数传递问题: 基本类型:形式参数的改变对实际参数没有影响.在参数传递过程中,形参和实参占用了两个完全不同的内存空间. 引用类型:形式参数的改变直接影响实际参数.在参数传递的过程中,形参和 ...

  10. Maven插件详解

    插件与插件目标 Maven定义了三套相互独立的生命周期,每套生命周期都有多个生命周期阶段,而这些阶段都是抽象的,不做任何工作.真正完成工作的是绑定在生命周期阶段的插件目标.插件以独立的构件形式存在,一 ...