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 18 Python
深入解析Python中的集合类型操作符
Aug 19 Python
Python实现带百分比的进度条
Jun 28 Python
python利用正则表达式提取字符串
Dec 08 Python
详解Python装饰器由浅入深
Dec 09 Python
利用Tkinter(python3.6)实现一个简单计算器
Dec 21 Python
Tensorflow 自带可视化Tensorboard使用方法(附项目代码)
Feb 10 Python
在Django中输出matplotlib生成的图片方法
May 24 Python
python爬虫之自制英汉字典
Jun 24 Python
anaconda如何查看并管理python环境
Jul 05 Python
python的移位操作实现详解
Aug 21 Python
python 实现体质指数BMI计算
May 26 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 mcrypt可逆加密算法分析
2011/07/19 PHP
单台服务器的PHP进程之间实现共享内存的方法
2014/06/13 PHP
php操作xml入门之xml基本介绍及xml标签元素
2015/01/23 PHP
PHP对象的浅复制与深复制的实例详解
2017/10/26 PHP
JScript中的"this"关键字使用方式补充材料
2007/03/08 Javascript
jQuery autocomplete插件修改
2009/04/17 Javascript
Prototype Array对象 学习
2009/07/19 Javascript
javascript 打开页面window.location和window.open的区别
2010/03/17 Javascript
JS控件ASP.NET的treeview控件全选或者取消(示例代码)
2013/12/16 Javascript
jQuery控制Div拖拽效果完整实例分析
2015/04/15 Javascript
jQuery中事件与动画的总结分享
2016/05/24 Javascript
Bootstrap登陆注册页面开发教程
2016/07/12 Javascript
基于JavaScript实现的希尔排序算法分析
2017/04/14 Javascript
React操作真实DOM实现动态吸底部的示例
2017/10/23 Javascript
详解使用mpvue开发github小程序总结
2018/07/25 Javascript
JS实现数组去重,显示重复元素及个数的方法示例
2019/01/21 Javascript
微信小程序常用赋值方法小结
2019/04/30 Javascript
Node配合WebSocket做多文件下载以及进度回传
2019/11/07 Javascript
微信小程序自定义yPicker组件实现省市区三级联动功能
2020/10/29 Javascript
详细解析Python中__init__()方法的高级应用
2015/05/11 Python
python3批量删除豆瓣分组下的好友的实现代码
2016/06/07 Python
使用memory_profiler监测python代码运行时内存消耗方法
2018/12/03 Python
Python如何调用JS文件中的函数
2019/08/16 Python
Jimmy Choo美国官网:周仰杰鞋子品牌
2018/06/08 全球购物
迪奥美国官网:Dior美国
2019/12/07 全球购物
哥德堡通行证:Gothenburg Pass
2019/12/09 全球购物
在求职信中如何凸显个人优势
2013/10/30 职场文书
学前班教师的自我鉴定
2013/12/05 职场文书
电子商务专员岗位职责
2013/12/11 职场文书
单位领导证婚词
2014/01/14 职场文书
信用卡工作证明模板
2014/09/14 职场文书
个人工作作风整改措施思想汇报
2014/10/13 职场文书
党风廉政建设调研报告
2015/01/01 职场文书
国庆放假通知怎么写
2015/07/30 职场文书
Redis6.0搭建集群Redis-cluster的方法
2021/05/08 Redis
详解Java实践之抽象工厂模式
2021/06/18 Java/Android