python之MySQLdb模块

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

防伪码:忘情公子著


  MySQLdb是用来通过python控制mysql数据库的一个模块。

  在说这个模块之前,我们先来想一下在命令行模式下操作mysql数据库的步骤,一般来说分为三步:

    1、连接数据库;

    2、操作数据库(通过sql语句);

    3、断开数据库连接

  按此思路可知,python中的MySQLdb也是需要经过这三个步骤的,只不过不是在命令行模式下手工执行而已。

  要想使用MySQLdb必须保证系统中有安装MySQL-python这个软件。

  本篇文章主要是讲MySQLdb模块的使用,至于安装的步骤,请自行上网查阅。

  MySQLdb模块在其内部提供了以下几个子模块:

    connections:专门用来建立连接

    constants(package)

    converters:实现将python中的字符串转换成mysql可以处理的数据类型

    cursors:游标。基于游标发送sql语句,获取执行结果

    release

    times

  

  MySQLdb模块的常用方法:

    在执行以下方法时,前面的connect和cursor均要替换成其实例化的对象名称。

    connect(*args, **kwargs):连接数据库。常用参数有以下这些

      user='Username'

      passwd='Password'

      host='Ip_Address'

     db='dbname' #默认操作哪个db

      port='Port_number'

      connect_timeout='连接超时时间'

      compress:实现压缩后进行数据传输


    connect.stat():查看连接状态

    connect.ping():测试正在连接的mysql服务器是否在线,不在线则尝试去重新连接

    connect.commit():提交当前事务

    connect.rollback():回滚事务

    connect.autocommit(self,on):设置自动提交事务功能,参数值为1时开启此功能,值为0时关闭此功能

    connect.thread_id():获取线程号

    connect.shutdown():关闭mysql服务(前提是连接的用户有权限关闭mysql服务)

    connect.cursor(self, cursorclass=None):通过connect连接对象创建游标对象

    connect.select_db('dbname'):选择一个数据库进行操作

    cursor.execute(self, query, args=None):通过cursor游标对象执行单条语句

    cursor.executemany(self, query, args):通过cursor游标对象执行多条语句

      这里的参数args必须是一个元组序列类型,可以是元组内包含元组,也可以是列表内包含元组

    cursor.fetchone(self):通过cursor游标对象取出执行查询语句后的单条记录。

      fetchone方法一次只能取一条记录;

      可以通过遍历循环的方式取得所有记录;

      默认只能从上往下查,无法从下往上查;

    cursor.fetchmany(self, size=None):通过cursor游标对象取出查询语句后的多条记录

      size参数用来设置取出多少条记录

      如:cursor.fetchmany(10)表示取出10条记录

    cursor.fetchall(self):通过cursor游标对象取出执行查询语句后的所有记录

    cursor.scroll(self, value, mode='relative'):控制数据指针的位置

      value参数:

        用来设置偏移位,也就是移动多少位置

      mode参数:

        默认是relative,也就是从当前位置开始偏移;

        当设置为absolute时表示绝对位置,从头开始偏移

        如:cursor.scroll(0,absolute)表示将指针移动到头部,从头开始,移动0位


  接下来我们来演示一下用MySQLdb模块实现mysql的增删改查功能

  在这里我们要操作的数据库名为aproduct,在aproduct库中有张表test2,查询出来内容如下:

1
2
3
4
5
6
7
8
mysql> select  *  from  test2;
+ - - - - - - - + - - - - - - + - - - - - - - - - + - - - - - - +
| name  | age  | job     | city |
+ - - - - - - - + - - - - - - + - - - - - - - - - + - - - - - - +
| tom   |    30  | teacher | SH   |
| jerry |    25  | doctor  | WC   |
+ - - - - - - - + - - - - - - + - - - - - - - - - + - - - - - - +
2  rows  in  set  ( 0.09  sec)

  创建一个连接对象:

1
conn  =  MySQLdb.connect(user = 'roo' ,passwd = 'abc123!' ,host = '127.0.0.1' )

  通过connect连接对象创建游标对象:

1
cur  =  conn.cursor()

  通过以上两个步骤就能正常连接到一个数据库,接下来就是操作数据库了。

  一般来说通过python来操作数据库指的是对数据库进行增、删、改、查,至于创建数据库最好是在数据库命令行界面下操作。

  假定我们要ss_product这个库进行操作,在命令行下我们需要用到use ss_product,但在python下是没有use命令的,但我们可以通过select_db来实现这个功能:

1
conn.select_db( 'aproduct' )

  通过cursor游标对象执行sql语句:

    在前面我们看到,test2这张表有四个字段,接下来我们给插入一条记录。

1
cur.execute( "insert into test2(name,age,job,city) value('sean',28,'Engineer','SH')" )

  我们在命令行下看看数据是否插入成功:

1
2
3
4
5
6
7
8
9
mysql> select  *  from  test2;
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| name  | age  | job      | city |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| tom   |    30  | teacher  | SH   |
| jerry |    25  | doctor   | WC   |
| sean  |    28  | Engineer | SH   |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
3  rows  in  set  ( 0.00  sec)

  由此可见,数据已经插入成功了,但这样插入数据会很麻烦。

  因为数据不可能是固定的,不可能每次插入数据都去修改SQL语句,所以我们通常将sql语句放到一个变量名中。

1
2
sqli  =  "insert into test2(name,age,job,city) value(%s,%s,%s,%s)"
cur.execute(sqli,( 'abc' , 30 , 'actor' , 'WH' ))

 在命令行里看看是否插入成功:

1
2
3
4
5
6
7
8
9
10
mysql> select  *  from  test2;
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| name  | age  | job      | city |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| tom   |    30  | teacher  | SH   |
| jerry |    25  | doctor   | WC   |
| sean  |    28  | Engineer | SH   |
| abc   |    30  | actor    | WH   |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
4  rows  in  set  ( 0.00  sec)

  可以看到,数据已经插入成功。这样的方式比之前面一种写死数据就要灵活得多了。

  但是这样只能一次插入一条数据,要想插入多条数据则需要像下面这样操作:

1
sqlim  =  "insert into test2(name,age,job,city) values(%s,%s,%s,%s)"

  当要插入多条数据时,通常把所有的数据放到values下,虽然不知道要插入多少数据,但是字段是固定的

  在本例中是4个字段,所以values内只需要我们给四个%s占位即可,这里只能使用%s进行占位。

  游标对象(cursor)的execute方法只能同时插入一条数据,想要同时插入多条数据则要使用executemany方法:

1
cur.executemany(sqlim,[( 'a123' , 40 , 'teacher' , 'NC' ),( 'a456' , 34 , 'Engineer' , 'BJ' ),( 'lisi' , 25 , 'worker' , 'GZ' )])

  注意:sqlim后面的参数必须是一个元组序列类型,可以是元组内包含元组,也可以是列表内包含元组。

  在命令行下看看数据库表的内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
mysql> select  *  from  test2;
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| name  | age  | job      | city |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| tom   |    30  | teacher  | SH   |
| jerry |    25  | doctor   | WC   |
| sean  |    28  | Engineer | SH   |
| abc   |    30  | actor    | WH   |
| a123  |    40  | teacher  | NC   |
| a456  |    34  | Engineer | BJ   |
| lisi  |    25  | worker   | GZ   |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
7  rows  in  set  ( 0.00  sec)

  接下来我们用同样的命令来尝试下删除”lisi“这条记录:

1
2
sqld  =  "delete from test2 where name='lisi'"
cur.execute(sqld)

  看看数据库结果:

1
2
3
4
5
6
7
8
9
10
11
12
mysql> select  *  from  test2;
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| name  | age  | job      | city |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| tom   |    30  | teacher  | SH   |
| jerry |    25  | doctor   | WC   |
| sean  |    28  | Engineer | SH   |
| abc   |    30  | actor    | WH   |
| a123  |    40  | teacher  | NC   |
| a456  |    34  | Engineer | BJ   |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
6  rows  in  set  ( 0.00  sec)

  接下来我们将名字叫abc的这条记录中的年龄给改成35:

1
2
sqlu  =  "update test2 set age=35 where name='abc'"
cur.execute(sqlu)

  进数据库看看结果:

1
2
3
4
5
6
7
8
9
10
11
12
mysql> select  *  from  test2;
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| name  | age  | job      | city |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
| tom   |    30  | teacher  | SH   |
| jerry |    25  | doctor   | WC   |
| sean  |    28  | Engineer | SH   |
| abc   |    35  | actor    | WH   |
| a123  |    40  | teacher  | NC   |
| a456  |    34  | Engineer | BJ   |
+ - - - - - - - + - - - - - - + - - - - - - - - - - + - - - - - - +
6  rows  in  set  ( 0.00  sec)

  接下来看看怎么查询:

    我们用sql语句在命令行中查询时会返回一张表,其类型如上例的结果所示。

    但在python中MySQLdb模块是无法实现打印出这种格式的,此时我们需要通过另一种方法来实现查询功能。

1
2
3
4
sqls  =  "select * from test2"
cur.execute(sqls)
cur.fetchone()       #查询一条记录
cur.fetchmany( 6 )     #查询6条记录

  MySQLdb模块中的查询是通过游标来控制的,我们可以通过cursor游标对象的scroll方法来控制游标。

  当sql语句执行完毕以后,我们需要断开数据库连接,分为以下几个步骤:

1
2
cur.close()      #断开游标
conn.close()     #断开数据库









本文转自 忘情OK  51CTO博客,原文链接:http://blog.51cto.com/itchentao/1891436,如需转载请自行联系原作者
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
9天前
|
Python
在Python中,可以使用内置的`re`模块来处理正则表达式
在Python中,可以使用内置的`re`模块来处理正则表达式
25 5
|
20天前
|
Java 程序员 开发者
Python的gc模块
Python的gc模块
|
23天前
|
数据采集 Web App开发 JavaScript
python-selenium模块详解!!!
Selenium 是一个强大的自动化测试工具,支持 Python 调用浏览器进行网页抓取。本文介绍了 Selenium 的安装、基本使用、元素定位、高级操作等内容。主要内容包括:发送请求、加载网页、元素定位、处理 Cookie、无头浏览器设置、页面等待、窗口和 iframe 切换等。通过示例代码帮助读者快速掌握 Selenium 的核心功能。
68 5
|
26天前
|
Python
SciPy 教程 之 SciPy 模块列表 6
SciPy教程之常量模块介绍:涵盖公制、二进制(字节)、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率及力学单位。示例展示了角度单位转换为弧度的几个常用常量。
19 7
|
26天前
|
Python
SciPy 教程 之 SciPy 模块列表 7
`scipy.constants` 模块提供了常用的时间单位转换为秒数的功能。例如,`constants.hour` 返回 3600.0 秒,表示一小时的秒数。其他常用时间单位包括分钟、天、周、年和儒略年。
18 6
|
23天前
|
Python
SciPy 教程 之 SciPy 模块列表 13
SciPy教程之SciPy模块列表13:单位类型。常量模块包含多种单位,如公制、二进制(字节)、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。示例代码展示了如何使用`constants`模块获取零摄氏度对应的开尔文值(273.15)和华氏度与摄氏度的转换系数(0.5556)。
18 1
|
24天前
|
XML 前端开发 数据格式
超级详细的python中bs4模块详解
Beautiful Soup 是一个用于从网页中抓取数据的 Python 库,提供了简单易用的函数来处理导航、搜索和修改分析树。支持多种解析器,如 Python 标准库中的 HTML 解析器和更强大的 lxml 解析器。通过简单的代码即可实现复杂的数据抓取任务。本文介绍了 Beautiful Soup 的安装、基本使用、对象类型、文档树遍历和搜索方法,以及 CSS 选择器的使用。
55 1
|
25天前
|
Python
SciPy 教程 之 SciPy 模块列表 9
SciPy教程之常量模块介绍,涵盖多种单位类型,如公制、质量、角度、时间、长度、压强等。示例展示了如何使用`scipy.constants`模块查询不同压强单位对应的帕斯卡值,包括atm、bar、torr、mmHg和psi。
15 1
|
25天前
|
Python
SciPy 教程 之 SciPy 模块列表 8
SciPy教程之常量模块单位类型介绍。该模块包含多种单位,如公制、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。示例展示了部分长度单位的转换值,例如英寸、英尺、海里等。
16 1
|
27天前
|
知识图谱 Python
SciPy 教程 之 SciPy 模块列表 5
本教程介绍SciPy常量模块中的单位类型,涵盖公制、质量、时间、长度等单位。示例代码展示了如何使用`scipy.constants`模块获取不同质量单位的千克值,如公吨、磅、盎司、原子质量单位等。
15 1
下一篇
无影云桌面