Python MySQLdb模块

安装

系统:Ubuntu 14.04
MySQLdb
$ pip install Mysql-python
-> 报错:EnvironmentError: mysql_config not found (安装libmysqlclient-dev)
$ apt-get install libmysqlclient-dev
$ pip install Mysql-python

如果是MAC系统,则需要先安装mysql服务。

使用

# coding=utf-8

import MySQLdb

conn = MySQLdb.connect(host='127.0.0.1', user='zheng', db='satezheng', passwd='satezheng')

cur = conn.cursor()

# 查
# 执行命令,并不会直接打印,可以使用fetchall来读取。
reCount1 = cur.execute('show tables;')
print reCount1      # 输出一个数字,是SQL影响的行数
# 循环输出结果,以元祖的方式输出
for data in cur.fetchall():
    print data

# 插入一条数据
# 执行增删改等命令时,可用如下方法。
sql1 = 'insert into Products(prod_id, prod_name) values(%s, %s);'
params = ('00002', 'GLA')
reCount2 = cur.execute(sql1, params)        #为了防止SQL注入,可以使用该方法
conn.commit()   #提交


# 批量插入
li = [
    ('000004', 'TYA'),
    ('000005', 'TUH')
]
sql1 = 'insert into Products(prod_id, prod_name) values(%s, %s);'
# 批量使用executemany
reCount23= cur.executemany(sql1, li)        #为了防止SQL注入,可以使用该方法
conn.commit()   #提交


cur.close()
conn.close()

上边查看数据时,返回是元祖形式,有时看起来并不明显,我们可以选择用字典的方式,将列名一起输出。

import MySQLdb

conn = MySQLdb.connect(host='127.0.0.1', user='zheng', db='satezheng', passwd='satezheng')

# 使用字典形式返回数据
cur = conn.cursor(cursorclass = MySQLdb.cursors.DictCursor)

# 执行命令,并不会直接打印,可以使用fetchall来读取。
reCount1 = cur.execute('select * from Products')

print reCount1      # 输出一个数字,是SQL影响的行数
for data in cur.fetchall():
    print data
cur.close()
conn.close()
# 结果==》
5
{'prod_name': 'hilife', 'prod_id': '00001'}
{'prod_name': 'GLA', 'prod_id': '00002'}
{'prod_name': 'GTL', 'prod_id': '00003'}
{'prod_name': 'TYA', 'prod_id': '000004'}
{'prod_name': 'TUH', 'prod_id': '000005'}

cursor读取执行结果的方法有:

  • fetchall() 把所有的都读出来
  • fetchmany(n) 输出指定数量n的行
  • fetchone 只返回第一条结果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 如果对于数据库不了解,可以先看这个 SQL教程:http://www.runoob.com/sql/sql-tut...
    打瞌睡的灰阅读 436评论 0 0
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,187评论 6 13
  • 一、实验目的 学习使用 weka 中的常用分类器,完成数据分类任务。 二、实验内容 了解 weka 中 explo...
    yigoh阅读 8,655评论 5 4
  • 空阁清风里。 孤阙城楼西。 伴影拾阶上 悠然月亮居。 ————《月居》,17.9.17凌晨随笔于阁楼书房,抒发了作...
    吴凡风之翼阅读 560评论 0 0
  • 我的房子在闹市 挤在人群和车水马龙中间 每晚可以看着霓虹一点点褪去色彩 还可以听见轮胎和鞋底摩擦马路的声音 我的房...
    Calm的大鹿阅读 303评论 2 0