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 只返回第一条结果

你可能感兴趣的:(Python MySQLdb模块)