一、基本概念

使用python操作数据库,其基本的流程如下(其实所有开发语言访问数据库的流程都是这样)。

1、第一,引入相应数据库的python数据库接口模块,针对不同的数据库类型,有不同的数据库访问接口模块。可以理解这些接口模块提供了一些api接口,让python代码可以访问数据库。

2、获取数据库的连接

3、执行sql语句

4、关闭数据库连接

二、下载python数据库接口包

比如对应mysql数据库,首先要下载相应的python mysql包。

可以到 https://pypi.python.org/pypi/MySQL-python/1.2.5 这个链接下下载,

对于windows系统,会有exe安装包,安装后,会在 Python27\Lib\site-packages 目录下生成mysql的包

三、代码编写

表结构如下: create table test(id int,info varchar(100))

#coding=utf-8
import time
import MySQLdb
try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('insert into test values(0,"x0")')
conn.commit()
cur.close()
conn.close()
print "finish insert direct"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('insert into test values(%s,%s)',(1,"x1"))
cur.execute('insert into test values(%s,%s)',[2,"x2"])
conn.commit()
cur.close()
conn.close()
print "finish insert by para"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
data=[];
data.append((3,"x3"));
data.append((4,"x4"));
cur.executemany('insert into test values(%s,%s)',data)
data=[];
data.append([5,"x5"]);
data.append([6,"x6"]);
cur.executemany('insert into test values(%s,%s)',data)
conn.commit()
cur.close()
conn.close()
print "finish muti insert by para"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('select * from test where id=%s',('')) #数字参数?
res=cur.fetchall()
for re in res:
print "id=%s,info=%s" % (re[0],re[1])
cur.close()
conn.close()
print "finish query where"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('select * from test')
res=cur.fetchall()
for re in res:
print "id=%s,info=%s" % (re[0],re[1])
cur.close()
conn.close()
print "finish query fetchall"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('select * from test') #游标指向第一条记录
re = cur.fetchone() #获取当前游标记录,同时游标指向下一条记录
print "id=%s,info=%s" % (re[0],re[1])
re = cur.fetchone()
print "id=%s,info=%s" % (re[0],re[1])
res=cur.fetchall() #获取当前游标记录及后续所有记录
for re in res:
print "id=%s,info=%s" % (re[0],re[1])
cur.close()
conn.close()
print "finish query fetchone"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('delete from test')
conn.commit()
cur.close()
conn.close()
print "finish delete"
except MySQLdb.Error,e:
print e.args[1]

需要说明的是,如果python脚本的字符集编码与数据库的字符集不一致,中文会出现乱码。

解决方法是在获取链接时指定数据库的字符集。如:

conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306,charset='gbk')

上面语句通过 增加 charset='gbk' 指定数据库的字符集。

Python 2.7 学习笔记 访问mysql数据库的更多相关文章

  1. SQLMAP学习笔记2 Mysql数据库注入

    SQLMAP学习笔记2 Mysql数据库注入 注入流程 (如果网站需要登录,就要用到cookie信息,通过F12开发者工具获取cookie信息) sqlmap -u "URL" - ...

  2. [Python] 学习笔记之MySQL数据库操作

    1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...

  3. mysql学习笔记之mysql数据库的安装

    1.执行mysql安装包选择自己定义安装(安装路径不要带中文,否则安装会出错! ) 2.一个mysql想要操作成功须要有三部分:server端,数据段,数据. 3.server软件文件夹: 4.数据文 ...

  4. 学习笔记:MySQL数据库初步 概念

    数据库 什么是数据库,数据库就是对大量信息进行管理的高效的解决方案,按照数据结构来组织.存储和管理数据的载体.而我们常说的数据库可以分为关系型和非关系型数据库. 关系型数据库 这里说的关系型数据库,是 ...

  5. PHP学习笔记:MySQL数据库的操纵

    Update语句 Update 表名 set 字段1=值1, 字段2=值2  where  条件 练习: 把用户名带  ‘小’的人的密码设置为123456@ 语句:UPDATE crm_user SE ...

  6. Python访问MySQL数据库并实现其增删改查功能

    概述:对于访问MySQL数据库的操作,我想大家也都有一些了解.不过,因为最近在学习Python,以下就用Python来实现它.其中包括创建数据库和数据表.插入记录.删除记录.修改记录数据.查询数据.删 ...

  7. 【python小记】访问mysql数据库

    题记: 最近因为工作需要,学习了python,瞬间对这个轻松快捷的语给吸引了,以前只知道js脚本是写网页的,没有想到python这个脚本语言的应用范围可以这么广泛,现在做一些简单或稍微复杂的操作,基本 ...

  8. Requests:Python HTTP Module学习笔记(一)(转)

    Requests:Python HTTP Module学习笔记(一) 在学习用python写爬虫的时候用到了Requests这个Http网络库,这个库简单好用并且功能强大,完全可以代替python的标 ...

  9. C#连接、访问MySQL数据库

    一.准备工具 visual stuido(本示例使用visual studio 2010) MySql.Data.dll mysql_installer_community_V5.6.21.1_set ...

随机推荐

  1. QT 子窗口监听主窗口信号(超级简单,但是好用,比如主窗口移动的时候,子窗口不要再继续处理任务)

    MainWindow *ptr = NULL; ptr = (MainWindow*)parentWidget(); connect(ptr, SIGNAL(param_result(bool)), ...

  2. JAVA中SSH面试问题

    1.阐述struts2的执行流程. Struts 2框架本身大致可以分为3个部分:核心控制器FilterDispatcher.业务控制器Action和用户实现的企业业务逻辑组件.核心控制器Filter ...

  3. Ext.net-00 VS配置

    1.configSections 节点配置 <section name="extnet" type="Ext.Net.GlobalConfig" requ ...

  4. objective-C学习笔记(二)类 class 和 结构 struct

    Objective-C的类型 引用类型 类 class 指针 pointer 块 block 值类型 基础数值类型 结构 struct 枚举 enum 类型装饰 协议 protocol 类别 cate ...

  5. UILabel显示html文本

    NSString * htmlString = @"<html><body> Some html string \n <font size=\"13\ ...

  6. iOS开发之第三方登录QQ -- 史上最全最新第三方登录QQ方式实现

    项目地址 :  https://github.com/zhonggaorong/QQLoginDemo/tree/master 最新版本的qq登录实现步骤实现: 1. 首先,你需要去向腾讯申请账号. ...

  7. json对象的操作,json工具

    项目中经常用到json,现在把写了几个js函数,用来获取json对象或者json字符串的长度,以及获取其的key值,value值,并且返回. 这样以后可以直接拿来用,可以省去不少麻烦,也方便以后查看. ...

  8. git配合tortoiseGit的基础使用

    转载自:http://www.cnblogs.com/ssor/archive/2012/02/04/2337823.html 一定要自己写出来才能牢记,所以我来写一下 git确实比svn好用的多了, ...

  9. JavaScript时钟实例

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  10. [mysql]子查询与连接

    1,子查询(Subquery)是指出现在其他 SQL 语句内的select子句 例如: select * from t1 where col1 = (select col2 from t2); 其中 ...