python数据库操作常用功能使用详解(创建表/插入数据/获取数据)


Posted in Python onDecember 06, 2013

实例1、取得MYSQL版本

# -*- coding: UTF-8 -*-
#安装MYSQL DB for python
import MySQLdb as mdb
con = None
try:
    #连接mysql的方法:connect('ip','user','password','dbname')
    con = mdb.connect('localhost', 'root',
        'root', 'test');
    #所有的查询,都在连接con的一个模块cursor上面运行的
    cur = con.cursor()
    #执行一个查询
    cur.execute("SELECT VERSION()")
    #取得上个查询的结果,是单个结果
    data = cur.fetchone()
    print "Database version : %s " % data
finally:
    if con:
        #无论如何,连接记得关闭
        con.close()

执行结果:
Database version : 5.5.25

实例2、创建一个表并且插入数据

# -*- coding: UTF-8 -*-
import MySQLdb as mdb
import sys
#将con设定为全局连接
con = mdb.connect('localhost', 'root', 'root', 'test');
with con:
    #获取连接的cursor,只有获取了cursor,我们才能进行各种操作
    cur = con.cursor()
    #创建一个数据表 writers(id,name)
    cur.execute("CREATE TABLE IF NOT EXISTS \
        Writers(Id INT PRIMARY KEY AUTO_INCREMENT, Name VARCHAR(25))")
    #以下插入了5条数据
    cur.execute("INSERT INTO Writers(Name) VALUES('Jack London')")
    cur.execute("INSERT INTO Writers(Name) VALUES('Honore de Balzac')")
    cur.execute("INSERT INTO Writers(Name) VALUES('Lion Feuchtwanger')")
    cur.execute("INSERT INTO Writers(Name) VALUES('Emile Zola')")
    cur.execute("INSERT INTO Writers(Name) VALUES('Truman Capote')")

实例3、python使用slect获取mysql的数据并遍历

# -*- coding: UTF-8 -*-
import MySQLdb as mdb
import sys
#连接mysql,获取连接的对象
con = mdb.connect('localhost', 'root', 'root', 'test');
with con:
    #仍然是,第一步要获取连接的cursor对象,用于执行查询
    cur = con.cursor()
    #类似于其他语言的query函数,execute是python中的执行查询函数
    cur.execute("SELECT * FROM Writers")
    #使用fetchall函数,将结果集(多维元组)存入rows里面
    rows = cur.fetchall()
    #依次遍历结果集,发现每个元素,就是表中的一条记录,用一个元组来显示
    for row in rows:
        print row
执行结果:
(1L, ‘Jack London')
(2L, ‘Honore de Balzac')
(3L, ‘Lion Feuchtwanger')
(4L, ‘Emile Zola')
(5L, ‘Truman Capote')

实例4、使用字典cursor取得结果集(可以使用表字段名字访问值)

# -*- coding: UTF-8 -*-
# 来源:疯狂的蚂蚁的博客www.server110.com总结整理
import MySQLdb as mdb
import sys
#获得mysql查询的链接对象
con = mdb.connect('localhost', 'root', 'root', 'test')
with con:
    #获取连接上的字典cursor,注意获取的方法,
    #每一个cursor其实都是cursor的子类
    cur = con.cursor(mdb.cursors.DictCursor)
    #执行语句不变
    cur.execute("SELECT * FROM Writers")
    #获取数据方法不变
    rows = cur.fetchall()
    #遍历数据也不变(比上一个更直接一点)
    for row in rows:
        #这里,可以使用键值对的方法,由键名字来获取数据
        print "%s %s" % (row["Id"], row["Name"])

实例5、获取单个表的字段名和信息的方法

# -*- coding: UTF-8 -*-
# 来源:疯狂的蚂蚁的博客www.server110.com总结整理
import MySQLdb as mdb
import sys
#获取数据库的链接对象
con = mdb.connect('localhost', 'root', 'root', 'test')
with con:
    #获取普通的查询cursor
    cur = con.cursor()
    cur.execute("SELECT * FROM Writers")
    rows = cur.fetchall()
    #获取连接对象的描述信息
    desc = cur.description
    print 'cur.description:',desc
    #打印表头,就是字段名字
    print "%s %3s" % (desc[0][0], desc[1][0])
    for row in rows:
        #打印结果
        print "%2s %3s" % row
运行结果: cur.description: ((‘Id', 3, 1, 11, 11, 0, 0), (‘Name', 253, 17, 25, 25, 0, 1))
Id Name
1 Jack London
2 Honore de Balzac
3 Lion Feuchtwanger
4 Emile Zola
5 Truman Capote

实例6、使用Prepared statements执行查询(更安全方便)

# -*- coding: UTF-8 -*-
# 来源:疯狂的蚂蚁的博客www.server110.com总结整理
import MySQLdb as mdb
import sys
con = mdb.connect('localhost', 'root', 'root', 'test')
with con:
    cur = con.cursor()
    #我们看到,这里可以通过写一个可以组装的sql语句来进行
    cur.execute("UPDATE Writers SET Name = %s WHERE Id = %s",
        ("Guy de Maupasant", "4"))
    #使用cur.rowcount获取影响了多少行
    print "Number of rows updated: %d" % cur.rowcount

结果:
Number of rows updated: 1
Python 相关文章推荐
python中关于时间和日期函数的常用计算总结(time和datatime)
Mar 08 Python
SublimeText 2编译python出错的解决方法(The system cannot find the file specified)
Nov 27 Python
Python复制文件操作实例详解
Nov 10 Python
python实现csv格式文件转为asc格式文件的方法
Mar 23 Python
Python实现抓取HTML网页并以PDF文件形式保存的方法
May 08 Python
python实现年会抽奖程序
Jan 22 Python
Python嵌套式数据结构实例浅析
Mar 05 Python
详解Python 解压缩文件
Apr 09 Python
Python shutil模块用法实例分析
Oct 02 Python
Python搭建代理IP池实现存储IP的方法
Oct 27 Python
python opencv根据颜色进行目标检测的方法示例
Jan 15 Python
Python开发五子棋小游戏
Apr 28 Python
python多线程编程方式分析示例详解
Dec 06 #Python
树莓派中python获取GY-85九轴模块信息示例
Dec 05 #Python
python线程锁(thread)学习示例
Dec 04 #Python
pyv8学习python和javascript变量进行交互
Dec 04 #Python
python使用PyV8执行javascript代码示例分享
Dec 04 #Python
python解析xml文件实例分享
Dec 04 #Python
python抓取某汽车网数据解析html存入excel示例
Dec 04 #Python
You might like
php生成xml简单实例代码
2009/12/16 PHP
php include加载文件两种方式效率比较
2010/08/08 PHP
php中引用符号(&)的使用详解
2013/11/13 PHP
分享一段PHP制作的中文拼音首字母工具类
2014/12/11 PHP
PHP笛卡尔积实现算法示例
2018/07/30 PHP
PHP商品秒杀问题解决方案实例详解【mysql与redis】
2019/07/22 PHP
国外Lightbox v2.03.3 最新版 下载
2007/10/17 Javascript
关于跨站脚本攻击问题
2011/12/22 Javascript
js实现遮罩层弹出框的方法
2015/01/15 Javascript
jQuery根据用户电脑是mac还是pc加载对应样式的方法
2015/06/26 Javascript
jQuery实现网页抖动的菜单抖动效果
2015/08/07 Javascript
JavaScript html5 canvas绘制时钟效果
2016/03/01 Javascript
AngularJs上传前预览图片的实例代码
2017/01/20 Javascript
原生JS 购物车及购物页面的cookie使用方法
2017/08/21 Javascript
javascript字体颜色控件的开发 JS实现字体控制
2017/11/27 Javascript
JavaScript模拟实现自由落体效果
2018/08/28 Javascript
详解element-ui中表单验证的三种方式
2019/09/18 Javascript
Bootstrap实现模态框效果
2019/09/30 Javascript
解决vue组件中click事件失效的问题
2019/11/09 Javascript
手写Vue源码之数据劫持示例详解
2021/01/04 Vue.js
[01:01:51]EG vs VG Supermajor小组赛B组 BO3 第二场 6.2
2018/06/03 DOTA
python删除过期文件的方法
2015/05/29 Python
python使用fork实现守护进程的方法
2017/11/16 Python
python实现引用其他路径包里面的模块
2020/03/09 Python
多个版本的python共存时使用pip的正确做法
2020/10/26 Python
HTML5页面中尝试调起APP功能
2017/09/12 HTML / CSS
Moda Italia荷兰:意大利男士服装
2019/08/31 全球购物
人民教师求职自荐信
2014/03/12 职场文书
人大调研汇报材料
2014/08/14 职场文书
学校运动会广播稿
2014/10/11 职场文书
内乡县衙导游词
2015/02/05 职场文书
普希金诗歌赏析(6首)
2019/08/22 职场文书
Python实现随机生成迷宫并自动寻路
2021/06/13 Python
一文了解JavaScript用Element Traversal新属性遍历子元素
2021/11/27 Javascript
CSS实现五种常用的2D转换
2021/12/06 HTML / CSS
利用Apache Common将java对象池化的问题
2022/06/16 Servers