美文网首页
Python MySQLdb模块

Python MySQLdb模块

作者: SateZheng | 来源:发表于2016-11-01 18:29 被阅读27次

安装

系统: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失败

    python安装MySQLdb失败 python版本访问数据库需要借助模块MySQLdb,安装MySQLdb的方法...

  • python: 操作mysql数据库

    安装MySQLdb 首先要安装MySQLdb模块,用来访问数据库。MySQLdb 是用于Python链接Mysql...

  • python 与 mysql 交互

    安装引入模块 * 安装mysql模块 sudo apt-get install python-mysqldb * ...

  • Python标准库系列之MySQLdb模块

    MySQLdb模块的主要功能就是提供Python操作MySQL数据库的一个API,通过MySQLdb模块我们可以对...

  • python 与 mysql 交互

    安装引入模块 安装mysql模块 sudo apt-get install python-mysqldb 在文件中...

  • Python 与 Mysql 交互

    安装引入模块 安装mysql模块 sudo apt-get install python-mysqldb 在文件中...

  • Python MySQLdb模块

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

  • python macOSMojve Library not lo

    在python引用MySQLdb模块后,报错信息如下: Library not loaded: libmysqlc...

  • python交互

    安装mysql模块sudo apt-get install python-mysqldb 在文件中引入模块impi...

  • python_MySQLdb

    需要在机器上添加MySQLdb模块,以便用python直接连接MySQL 默认情况下,MySQLdb包是没有安装的...

网友评论

      本文标题:Python MySQLdb模块

      本文链接:https://www.haomeiwen.com/subject/dfgmuttx.html