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深入学习之内存管理
Aug 31 Python
在Python中操作字典之setdefault()方法的使用
May 21 Python
Python3实现从指定路径查找文件的方法
May 22 Python
Python数据分析之如何利用pandas查询数据示例代码
Sep 01 Python
Python2随机数列生成器简单实例
Sep 04 Python
通过Python 获取Android设备信息的轻量级框架
Dec 18 Python
python随机取list中的元素方法
Apr 08 Python
Numpy对数组的操作:创建、变形(升降维等)、计算、取值、复制、分割、合并
Aug 28 Python
python线程的几种创建方式详解
Aug 29 Python
python 实现将Numpy数组保存为图像
Jan 09 Python
python GUI库图形界面开发之PyQt5动态(可拖动控件大小)布局控件QSplitter详细使用方法与实例
Mar 06 Python
Python Matplotlib库实现画局部图
Nov 17 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 高手之路(三)
2006/10/09 PHP
PHP 编写的 25个游戏脚本
2009/05/11 PHP
IIS6+PHP5+MySQL5+Zend Optimizer+phpMyAdmin安装配置图文教程 2009年
2009/06/08 PHP
php array_unique之后json_encode需要注意
2011/01/02 PHP
php的chr和ord函数实现字符加减乘除运算实现代码
2011/12/05 PHP
destoon实现不同会员组公司名称显示不同的颜色的方法
2014/08/22 PHP
ThinkPHP3.2.3数据库设置新特性
2015/03/05 PHP
基于jquery的回到页面顶部按钮
2011/06/27 Javascript
Javascript模块化编程(一)AMD规范(规范使用模块)
2013/01/17 Javascript
热点新闻滚动特效的js代码
2013/08/17 Javascript
js的Boolean对象初始值示例
2014/03/04 Javascript
jquery实现漂亮的二级下拉菜单代码
2015/08/26 Javascript
JavaScript文档碎片操作实例分析
2015/12/12 Javascript
ichart.js绘制虚线、平均分虚线效果的实现代码
2016/05/05 Javascript
JS函数的定义与调用方法推荐
2016/05/12 Javascript
Vue实现动态响应数据变化
2017/04/28 Javascript
JavaScript禁止微信浏览器下拉回弹效果
2017/05/16 Javascript
vue2.0 中#$emit,$on的使用详解
2017/06/07 Javascript
javascript中关于类型判断的一些疑惑小结
2018/10/14 Javascript
只有 20 行的 JavaScript 模板引擎实例详解
2020/05/11 Javascript
python每次处理固定个数的字符的方法总结
2013/01/29 Python
Python网络编程 Python套接字编程
2017/09/13 Python
Python输出带颜色的字符串实例
2017/10/10 Python
浅谈numpy数组中冒号和负号的含义
2018/04/18 Python
深入浅析Python 命令行模块 Click
2020/03/11 Python
python中类与对象之间的关系详解
2020/12/16 Python
美国在线眼镜商城:Eyeglasses.com
2017/06/26 全球购物
斯图尔特·韦茨曼鞋加拿大官网:Stuart Weitzman加拿大
2019/10/13 全球购物
linux面试相关问题
2013/04/28 面试题
医务人员竞聘职务自我评价分享
2013/11/08 职场文书
总经理岗位职责范本
2014/02/02 职场文书
护士岗位求职应聘自荐书范文
2014/02/12 职场文书
党的群众路线教育实践活动实施方案
2014/10/31 职场文书
单位实习介绍信
2015/05/05 职场文书
2015年清剿火患专项行动工作总结
2015/07/27 职场文书
Mysql将字符串按照指定字符分割的正确方法
2022/05/30 MySQL