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打开url并按指定块读取网页内容的方法
Apr 29 Python
用Python编写生成树状结构的文件目录的脚本的教程
May 04 Python
python提取页面内url列表的方法
May 25 Python
python通过socket实现多个连接并实现ssh功能详解
Nov 08 Python
Python基础教程之内置函数locals()和globals()用法分析
Mar 16 Python
python中sort和sorted排序的实例方法
Aug 26 Python
python 消费 kafka 数据教程
Dec 21 Python
python爬虫添加请求头代码实例
Dec 28 Python
python标准库OS模块详解
Mar 10 Python
Python BeautifulReport可视化报告代码实例
Apr 13 Python
Python连续赋值需要注意的一些问题
Jun 03 Python
尝试使用Python爬取城市租房信息
Apr 12 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实现域名whois查询的代码(数据源万网、新网)
2010/02/22 PHP
php恢复数组的key为数字序列的方法
2015/04/28 PHP
用javascript实现的仿Flash广告图片轮换效果
2007/04/24 Javascript
javascript实现图片跟随鼠标移动效果的方法
2015/05/13 Javascript
js+canvas简单绘制圆圈的方法
2016/01/28 Javascript
浅谈React 属性和状态的一些总结
2016/11/21 Javascript
JS实现的简单图片切换功能示例【测试可用】
2017/02/14 Javascript
jQuery时间验证和转换为标准格式的时间格式
2017/03/06 Javascript
jquery仿ps颜色拾取功能
2017/03/08 Javascript
完美实现js选项卡切换效果(二)
2017/03/08 Javascript
原生javascript实现分页效果
2017/04/21 Javascript
vue使用Axios做ajax请求详解
2017/06/07 Javascript
JS中的三个循环小结
2017/06/20 Javascript
Angular中响应式表单的三种更新值方法详析
2017/08/22 Javascript
vue+element-ui+ajax实现一个表格的实例
2018/03/09 Javascript
VUE重点问题总结
2018/03/19 Javascript
select2 ajax 设置默认值,初始值的方法
2018/08/09 Javascript
对vux点击事件的优化详解
2018/08/28 Javascript
layui table 获取分页 limit的方法
2019/09/20 Javascript
原生JS运动实现轮播图
2021/01/02 Javascript
使用django-suit为django 1.7 admin后台添加模板
2014/11/18 Python
Python脚本实现DNSPod DNS动态解析域名
2015/02/14 Python
Python中列表元素转为数字的方法分析
2016/06/14 Python
urllib和BeautifulSoup爬取维基百科的词条简单实例
2018/01/17 Python
python pandas读取csv后,获取列标签的方法
2018/11/12 Python
Pandas Shift函数的基础入门学习笔记
2018/11/16 Python
Python进阶之自定义对象实现切片功能
2019/01/07 Python
Python实现html转换为pdf报告(生成pdf报告)功能示例
2019/05/04 Python
对Python3之方法的覆盖与super函数详解
2019/06/26 Python
python使用建议与技巧分享(一)
2020/08/17 Python
社区版pycharm创建django项目的方法(pycharm的newproject左侧没有项目选项)
2020/09/23 Python
HTML5 LocalStorage 本地存储详细概括(多图)
2017/08/18 HTML / CSS
SmartBuyGlasses荷兰:购买太阳镜和眼镜
2020/03/16 全球购物
网络编辑求职信
2014/04/30 职场文书
国庆节慰问信
2015/02/15 职场文书
css之clearfix的用法深入理解(必看篇)
2023/05/21 HTML / CSS