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实现拉钩网上的FizzBuzzWhizz问题示例
May 05 Python
python实现字典(dict)和字符串(string)的相互转换方法
Mar 01 Python
Python操作Excel之xlsx文件
Mar 24 Python
Python实现嵌套列表及字典并按某一元素去重复功能示例
Nov 30 Python
Python中shapefile转换geojson的示例
Jan 03 Python
python 实现图片旋转 上下左右 180度旋转的示例
Jan 24 Python
python读csv文件时指定行为表头或无表头的方法
Jun 26 Python
Python 占位符的使用方法详解
Jul 10 Python
python中有帮助函数吗
Jun 19 Python
python实现简单反弹球游戏
Apr 12 Python
浅谈哪个Python库才最适合做数据可视化
Jun 28 Python
python中pd.cut()与pd.qcut()的对比及示例
Jun 16 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
让你的网站首页自动选择语言转跳
2006/12/06 PHP
PHP中date与gmdate的区别及默认时区设置
2014/05/12 PHP
jquery 最简单的属性菜单
2009/10/08 Javascript
jquery中的$(document).ready()与window.onload的区别
2009/11/18 Javascript
jquery实用代码片段集合
2010/08/12 Javascript
Javascript Web Slider 焦点图示例源码
2013/10/10 Javascript
Javascript优化技巧之短路表达式详细介绍
2015/03/27 Javascript
js实现兼容IE和FF的上下层的移动
2015/05/04 Javascript
jQuery团购倒计时特效实现方法
2015/05/07 Javascript
基于JavaScript实现全屏透明遮罩div层锁屏效果
2016/01/26 Javascript
javascript弹出带文字信息的提示框效果
2016/07/19 Javascript
微信小程序实现全国机场索引列表
2018/01/31 Javascript
jQuery实现定时隐藏对话框的方法分析
2018/02/12 jQuery
《javascript设计模式》学习笔记一:Javascript面向对象程序设计对象成员的定义分析
2020/04/07 Javascript
vue实现给div绑定keyup的enter事件
2020/07/31 Javascript
[05:02]2014DOTA2 TI中国区预选赛精彩TOPPLAY第三弹
2014/06/25 DOTA
python提取页面内url列表的方法
2015/05/25 Python
Python实现信用卡系统(支持购物、转账、存取钱)
2016/06/24 Python
Django框架文件上传与自定义图片上传路径、上传文件名操作分析
2019/05/10 Python
Python IDLE或shell中切换路径的操作
2020/03/09 Python
Python使用Matlab命令过程解析
2020/06/04 Python
利用CSS3实现的文字定时向上滚动
2016/08/29 HTML / CSS
FC-Moto美国:欧洲最大的摩托车服装和头盔商店之一
2019/08/24 全球购物
文言文形式的学生求职信
2013/12/03 职场文书
个人优缺点自我评价
2014/01/27 职场文书
小学生学雷锋演讲稿
2014/04/25 职场文书
电子商务求职信
2014/06/15 职场文书
2014年师德师风自我剖析材料
2014/09/27 职场文书
学习退步检讨书
2014/09/28 职场文书
工作失职检讨书500字
2014/10/17 职场文书
感谢信怎么写
2015/01/21 职场文书
实施意见格式范本
2015/06/05 职场文书
干货:企业内部人才推荐奖励方案!
2019/07/09 职场文书
500字作文之关于爸爸
2019/11/14 职场文书
CSS3 制作的彩虹按钮样式
2021/04/11 HTML / CSS
戴尔Win11系统no bootable devices found解决教程
2022/09/23 数码科技