多次使用python操作mysql数据库,先与大家分享一下,关于如何使用python操作mysql数据库。mysql并不是python自带的模块,因此需要下载安装。(在windows平台下介绍该使用过程)

1、下载/安装python-mysql

下载地址:https://pypi.python.org/pypi/MySQL-python/1.2.5

双击下载的文件,一直选择next就可以安装好(前提是必须已经安装了python),注意python-mysql与python对应的版本,否则在使用过程中会出现意想不到的错误。

2、检查是否安装成功

打开python交互界面,输入import MySQLdb,没有报错表示成功安装。

如图:

3、使用方式

测试数据库为:

3.1 与数据库建立连接

1
2
3
4
5
6
7
8
9
# 使用MySQLdb.connect()方法
connection = MySQLdb.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="test")
# host : 主机名(IP)
# port : 端口号,mysql默认为3306
# user : 用户名
# passwd : 密码
# db : 数据库(默认连接的数据库)【可选】
# charset : 编码方式【可选】
# 如果未指定db属性,那么可以使用connection.select_db("数据库名称")选择指定数据库

3.2 获取游标对象

1
2
3
# 具体的sql执行,都是通过游标对象完成的;通过连接对象的cursor方法获取游标对象
# 初始状态游标执行第一个元素
cursor = connection.cursor()

3.3 执行SQL语句

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# 分为单个SQL执行和批量SQL执行,以及是否参数化(可以防止SQL注入)
# query: sql字符串
# args :如果sql字符串为%s占位符那么args是元组或者列表,如果sql字符串占位符是%(key)s形式## ,那么是字典类型。否则为None(默认)
# 语法1:cursor.execute(query, args)
# 语法2:cursor.executemany(query, args) 
# 范例1:使用语法1查询数据
import MySQLdb
if __name__ == "__main__":
    # create mysql connection
    connection = MySQLdb.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="test")
    # get cursor 
    cursor = connection.cursor()
    # 返回执行结果数
    # nums = cursor.execute("select * from user where id=%s", [1]) # 使用%s占位符
    nums = cursor.execute("select * from user where id = %(id)s", {"id" 1}) # 使用%(key)s占位符
    print(nums)
    print(cursor.fetchone())
     
# 范例2:使用语法2查询一条数据
import MySQLdb
 
if __name__ == "__main__":
    # create mysql connection
    connection = MySQLdb.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="test")
    # get cursor 
    cursor = connection.cursor()
    # 返回执行结果数;
    nums = cursor.executemany("select * from user where id=%s", [[1], [2]]) 
    print(nums)
    print(cursor.fetchone())
    print(cursor.fetchmany())
    print(cursor.fetchall())
# 结果是:nums = 2, 但是查询结果却是id=2的结果;那是因为nums表示执行了多少个execute方法,# 而执行查询结果,却是覆盖了上一个结果,因此当使用语法2查询时,执行返回最后一个条件的结果

对上述两种语法,这里做一些阐述:

1、execute:执行单条sql语句,并返回sql语句执行的结果数量

2、executemany:执行多条sql语句,内部实际是多次调用execute,但是比显示这样调用效率要高一些,返回execute执行成功的数量(实际就是sql语句的sql执行的结果数量。

当执行更新(插入、修改、删除)操作时,需要通过connection.commit()显示执行提交,才会将execute或者executemany执行的结果,映射到数据库中。

当执行查询操作时,需要使用cursor.fetchone()、cursor.fetchmany(size), cursor.fetchall(),获取一个、多个、全部sql执行查询的结果。如果使用cursor.frtchmany()默认会获取一个,如果想获取指定个数,那么可以使用cursor.fetchmany(size=2)方式。

3.4 查询时游标的理解

3.4.1 游标规则

如果使用同一个cursor.execute()执行查询结果,初始状态游标执行首个元素,当使用cursor.fetch*时,游标会向下移动;

cursor.fetchone : 向下移动一个位置

cursor.fetchmany(size=num) : 向下移动size指定数值位置

cursor.fetchall() :游标移动到末尾

例如:

1
2
3
4
5
6
7
8
9
10
11
12
import MySQLdb
 
if __name__ == "__main__":
    # create mysql connection
    connection = MySQLdb.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="test")
    # get cursor 
    cursor = connection.cursor()
    # 返回执行结果数
    nums = cursor.execute("select * from user"
    print(cursor.fetchone())
    print(cursor.fetchmany(size=1))
    print(cursor.fetchall())

执行结果:

(1L, 'admin')

((2L, 'wangzp'),)

((6L, 'wangzp12'), (5L, 'wangzp123'))

根据结果可以发现,游标会移动,按照上述描述的规则。

3.4.2 设置游标位置

可以通过cursor.scroll(position, mode="relative | absolute")方法,来设置相对位置游标和绝对位置游标。

方法参数描述:

position : 游标位置

mode : 游标位置的模式,relative:默认模式,相对当前位置;absolute:绝对位置

例如:

mode=relative, position=1;表示的是设置游标为当前位置+1的位置,即向下移动一个位置

mode=absolute, position=2;将游标移动到索引为2的位置

代码示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
import MySQLdb
 
if __name__ == "__main__":
    # create mysql connection
    connection = MySQLdb.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="test")
    # get cursor 
    cursor = connection.cursor()
    # 返回执行结果数
    nums = cursor.execute("select * from user"
    print(cursor.fetchone()) # 执行后,游标移动到索引位置为1
    cursor.scroll(1# 相对游标移动模式,当前索引+1,即游标位置为2
    print(cursor.fetchmany(size=1)) # 因此获取第3个元素
    cursor.scroll(0, mode="absolute"# 绝对索引模式,将游标重置为0
    print(cursor.fetchall()) # 因此获取所有数据

运行结果:

(1L, 'admin')

((6L, 'wangzp12'),)

((1L, 'admin'), (2L, 'wangzp'), (6L, 'wangzp12'), (5L, 'wangzp123'))

3.5 事务管理

使用connection.commit()提交,connection.rollback()回滚。

总结:

除了上述一些用法外,还有一些注入执行存储过程等方法,这里不做介绍,详情可以参考相关文档。其实用法相对还是比较简单的。一般开发可以分为如下步骤:

1、建立数据库连接

2、获取游标

3、执行SQL

4、如果sql是查询,那么使用fetch系列函数查询,但是需要注意的是游标的移动方式。

如下列一个简单的封装代码(部分):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import MySQLdb
 
class DBUtil(object):
     
    @staticmethod
    def getConnection(host, port, user, password, db):
        "get mysql connection"
        connection = None
        try:
            connection = MySQLdb.connect(host=host, port=port, user=user, passwd=password, db=db)
        except MySQLdb.Error, e:
            print(e)
        return connection
         
    @staticmethod
    def getCursor(connection):
        "get cursor"
        cursor = None
        try:
            cursor = connection.cursor()
        except MySQLdb.Error, e:
            print(e)
        return cursor
         
    @staticmethod
    def update(cursor, sql, args):
        return cursor.execute(sql, args)
         
    @staticmethod
    def updateAndCommit(connection, cursor, sql, args):
        nums = cursor.execute(sql, args)
        connection.commit()
        return nums
     
    @staticmethod
    def updateBatch(cursor, sql, args):
        return cursor.executemany(sql, args)
         
    @staticmethod
    def updateBatchAndCommit(connection, cursor, sql, args):
        nums = cursor.executemany(sql, args)
        connection.commit()
        return nums
     
if __name__ == "__main__":
        
    connection = DBUtil.getConnection("127.0.0.1"3306"root""root""test")
    cursor = DBUtil.getCursor(connection)
    nums = cursor.execute("select * from user")
    print(cursor.fetchall())

 

python mysql模块的更多相关文章

  1. ubuntu 安装python mysql模块

    Installation Starting with a vanilla Lucid install , install pip and upgrade to the latest version: ...

  2. Python Paramiko模块与MySQL数据库操作

    Paramiko模块批量管理:通过调用ssh协议进行远程机器的批量命令执行. 要使用paramiko模块那就必须先安装这个第三方模块,仅需要在本地上安装相应的软件(python以及PyCrypto), ...

  3. yum安装memcache,mongo扩展以及python的mysql模块安装

    //启动memcached/usr/local/memcached/bin/memcached -d -c 10240 -m 1024 -p 11211 -u root/usr/local/memca ...

  4. Python MySQLdb模块连接操作mysql数据库实例_python

    mysql是一个优秀的开源数据库,它现在的应用非常的广泛,因此很有必要简单的介绍一下用python操作mysql数据库的方法.python操作数据库需要安装一个第三方的模块,在http://mysql ...

  5. Python 操作 Mysql 模块

    一.Python 操作 Mysql 模块的安装 linux: yum install MySQL-python window: http://files.cnblogs.com/files/wupei ...

  6. python自动化--模块操作之re、MySQL、Excel

    一.python自有模块正则 import re # re.match只匹配字符串的开始,如果字符串开始不符合正则表达式,则匹配失败,函数返回None print(re.match("www ...

  7. python mysql

    mysql Linux 安装mysql: apt-get install mysql-server 安装python-mysql模块:apt-get install python-mysqldb Wi ...

  8. Python Mysql 篇

    Python 操作 Mysql 模块的安装 linux: yum install MySQL-python window: http://files.cnblogs.com/files/wupeiqi ...

  9. python 常用模块(转载)

    转载地址:http://codeweblog.com/python-%e5%b8%b8%e7%94%a8%e6%a8%a1%e5%9d%97/ adodb:我们领导推荐的数据库连接组件bsddb3:B ...

随机推荐

  1. ZOJ 2314 Reactor Cooling(无源汇上下界网络流)

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2314 题意: 给出每条边流量的上下界,问是否存在可行流,如果存在则输出. ...

  2. Hardcoded string should use @string resource 警告

    在布局文件中,文本的设置使用如下写法时会有警告:Hardcoded string "下一步", should use @string resource <Button and ...

  3. mybatis 环境搭建和基本说明

    mybatis介绍就不多提了,直接步入正题. 先准备好eclipse和MySQL,然后先看一下目录结构 文件和类很少,所以mybatis的搭建是非常简单的,如搭建中遇到问题可以先参考文档最后一部分的综 ...

  4. 雷林鹏分享:Ruby 正则表达式

    Ruby 正则表达式 正则表达式是一种特殊序列的字符,它通过使用有专门语法的模式来匹配或查找其他字符串或字符串集合. 语法 正则表达式从字面上看是一种介于斜杠之间或介于跟在 %r 后的任意分隔符之间的 ...

  5. Rails 5 Test Prescriptions 第10章 Testing for Security

    Web 安全是一个可怕的主题.所有的你的程序都依靠密码学,代码超出了你的控制. 尽管如此,你还是可以控制部分网页安全 --所有的logins和access checks和injection error ...

  6. CentOS下安装Telnet服务

    环境:centos6.6   IP:172.18.0.190 1.查看是否安装Telnet: rpm -qa telnet-server rpm -qa xinetd 2.安装Telnet: yum ...

  7. RabbitMQ三种Exchange模式

    RabbitMQ中,所有生产者提交的消息都由Exchange来接受,然后Exchange按照特定的策略转发到Queue进行存储 RabbitMQ提供了四种Exchange:fanout,direct, ...

  8. 12.19 redis缓存

    ---恢复内容开始--- 命中:应用程序从key中获取数据,取到后返回 失效:到设置的失效时间后就失效 更新:应用程序把数据存到数据库中后又放回去 在项目中使用redis方法 结合业务场景,避免滥用 ...

  9. Bandicam下载 + 破解

    BANDICAM是一款屏幕游戏录制工具. 今天给大家详细介绍下它的下载和破解使用. 安装方法: 一.准备工作 1.官网下载最新版. https://www.bandicam.com/cn/ 2.下载注 ...

  10. 为什么要使用索引?-Innodb与Myisam引擎的区别与应用场景

    Innodb与Myisam引擎的区别与应用场景 http://www.cnblogs.com/changna1314/p/6878900.html https://www.cnblogs.com/ho ...