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 Web框架Flask中使用七牛云存储实例
Feb 08 Python
Python的Bottle框架中返回静态文件和JSON对象的方法
Apr 30 Python
使用Python中的tkinter模块作图的方法
Feb 07 Python
python 内置函数filter
Jun 01 Python
python调用系统ffmpeg实现视频截图、http发送
Mar 06 Python
tensorflow实现逻辑回归模型
Sep 08 Python
python实现Dijkstra静态寻路算法
Jan 17 Python
python实现简单聊天室功能 可以私聊
Jul 12 Python
python datetime中strptime用法详解
Aug 29 Python
Python Sphinx使用实例及问题解决
Jan 17 Python
Django如何使用jwt获取用户信息
Apr 21 Python
2020版Python学习路线图(附学习资料)
Sep 15 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
spl_autoload_register与autoload的区别详解
2013/06/03 PHP
Codeigniter框架实现获取分页数据和总条数的方法
2014/12/05 PHP
PHP可变函数学习小结
2015/11/29 PHP
jQuery 表单验证扩展代码(二)
2010/10/20 Javascript
jquery $.getJSON()跨域请求
2011/12/21 Javascript
Js制作简单弹出层DIV在页面居中 中间显示遮罩的具体方法
2013/08/08 Javascript
js获取当前页面路径示例讲解
2014/01/08 Javascript
JavaScript 学习笔记之变量及其作用域
2015/01/14 Javascript
JS实现的表格操作类详解(添加,删除,排序,上移,下移)
2015/12/22 Javascript
基于Angularjs实现分页功能
2016/05/30 Javascript
javascript设计模式之单体模式学习笔记
2017/02/15 Javascript
Vue进度条progressbar组件功能
2018/04/17 Javascript
详解关于element el-button使用$attrs的一个注意要点
2018/11/09 Javascript
vue模式history下在iis中配置流程
2019/04/17 Javascript
javascript导出csv文件(excel)的方法示例
2019/08/25 Javascript
VUE项目中加载已保存的笔记实例方法
2019/09/14 Javascript
jquery传参及获取方式(两种方式)
2020/02/13 jQuery
[01:11]steam端dota2实名认证操作流程视频
2021/03/11 DOTA
Python实现SVN的目录周期性备份实例
2015/07/17 Python
Python2.7.10以上pip更新及其他包的安装教程
2018/06/12 Python
python range()函数取反序遍历sequence的方法
2018/06/25 Python
Python 利用内置set函数对字符串和列表进行去重的方法
2018/06/29 Python
python集合比较(交集,并集,差集)方法详解
2018/09/13 Python
python随机在一张图像上截取任意大小图片的方法
2019/01/24 Python
Python分析彩票记录并预测中奖号码过程详解
2019/07/09 Python
Django中create和save方法的不同
2019/08/13 Python
django列表筛选功能的实现代码
2020/03/27 Python
基于python实现对文件进行切分行
2020/04/26 Python
使用sublime text3搭建Python编辑环境的实现
2021/01/12 Python
AmazeUI在模态框中嵌入表单形成模态输入框
2020/08/20 HTML / CSS
Dune London官网:英国著名奢华鞋履品牌
2017/11/30 全球购物
捷克移动配件网上商店:ProMobily.cz
2019/03/15 全球购物
室内设计专业个人的自我评价
2013/10/19 职场文书
工作粗心大意检讨书
2014/09/18 职场文书
小学四年级学生评语
2014/12/26 职场文书
2015年小学语文工作总结
2015/05/25 职场文书