广告
返回顶部
首页 > 资讯 > 数据库 >python之MySQLdb模块
  • 987
分享到

python之MySQLdb模块

2024-04-02 19:04:59 987人浏览 安东尼
摘要

防伪码:忘情公子著  Mysqldb是用来通过python控制mysql数据库的一个模块。  在说这个模块之前,我们先来想一下在命令行模式下操作mysql数据库的步骤,一般来说分为三步:

防伪码:忘情公子著


  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,查询出来内容如下:

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

  创建一个连接对象:

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

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

cur = conn.cursor()

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

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

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

conn.select_db('aproduct')

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

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

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

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

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语句放到一个变量名中。

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

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

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)

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

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

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

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

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

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

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

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

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

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“这条记录:

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

  看看数据库结果:

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:

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

  进数据库看看结果:

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模块是无法实现打印出这种格式的,此时我们需要通过另一种方法来实现查询功能。

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

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

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

cur.close()     #断开游标
conn.close()    #断开数据库
您可能感兴趣的文档:

--结束END--

本文标题: python之MySQLdb模块

本文链接: https://www.lsjlt.com/news/35654.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python之MySQLdb模块
    防伪码:忘情公子著  MySQLdb是用来通过python控制mysql数据库的一个模块。  在说这个模块之前,我们先来想一下在命令行模式下操作mysql数据库的步骤,一般来说分为三步:...
    99+
    2022-10-18
  • Python学习之MySQLdb模块
    CentOS下安装sudo yum install MySQL-python可以参考http://www.mikusa.com/python-mysql-docs/index.html  获取更多信息MySQL-python 为Python...
    99+
    2023-01-31
    模块 Python MySQLdb
  • python MySQLdb 模块
      用python操作mysql数据库,就会用到MySQLdb模块,这个模块其实和文件数据库SQLite的操作方式一样的先来看一下这模块的简单实用插入数据import MySQLdb #创建一个mysql的连接对象   conn = MyS...
    99+
    2023-01-31
    模块 python MySQLdb
  • python安装mysqldb模块
    mysqldb模块已经很久没有在维护了,但是很多人习惯使用mysqldb.从官方下载的安装包是32位,而我们的系统都是64位的因此安装会找不到python的环境变量或会报下面错误 python version2.7 required,whi...
    99+
    2023-01-31
    模块 python mysqldb
  • Python中如何安装MySQLDb模块
    这篇文章将为大家详细讲解有关Python中如何安装MySQLDb模块,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1,看看有没有安装进入python的命令行,输入 import MySQLd...
    99+
    2023-06-17
  • 如何使用 pip 安装 Python MySQLdb 模块?
    要安装Python MySQLdb模块,我们需要安装Python当前版本,即3.7 我们需要找到 pip 命令所在的 Python 脚本的位置。首先,打开cmd并到达Python脚本的位置。 要打开 cmd,请按“Windows+R”并键入...
    99+
    2023-10-22
  • Python时间模块之datetime模块
    目录 简介 函数介绍及运用 date:日期类 1.获取当前时间  2.日期对象的属性 3.date类中时间和时间戳的转换: 4.修改日期使用replace方法  time:时间类  time类操作 datetime:日期时间类 timede...
    99+
    2023-09-12
    python datetime python 日期时间
  • Python模块学习之IPy模块
    IP地址规划是网络设计中非常重要的一个环节,规划的好坏会直接影响路由协议算法的效率,包括网络性能、可扩展性等方面,在这个过程当中,免不了要计算大量的IP地址,包括网段、网络掩码、广播地址、子网数、IP类型等。Python提供了一个强大的第...
    99+
    2023-01-31
    模块 Python IPy
  • python之MySQLdb库的使用
     在开发的过程中避免不了和数据库的交互,在实际环境中用的最多的Mysql数据库,那python是怎么和Mysql进行交互的呢,python使用一个叫MySQLdb的库来连接MySQL,好的,下面最要从MySQLdb的安装、连接MySQL、...
    99+
    2023-01-31
    python MySQLdb
  • python模块之shutil
    shutil模块提供了一些针对文件和目录的高级操作,主要是拷贝、移动。对于单个文件的操作,还可参考os模块 Warning:即使是高级别的拷贝函数(shutil.copy(),shutil.copy2())也不能拷贝所有的文件元数据。意思...
    99+
    2023-01-31
    模块 python shutil
  • python模块之hashlib
    hashlib模块实现了多种安全哈希和信息摘要算法的通用接口,包括FIPS中定义的SHA1, SHA224, SHA256, SHA384, SHA512以及RFC 1321中定义的MD5 注意点:1. adler32及crc32哈希由z...
    99+
    2023-01-31
    模块 python hashlib
  • Python模块之: configobj
    原来也有写过一篇文章Python模块之: ConfigParser 用来解析INI文件,但是在使用过程中存在一些问题。比如:1,不能区分大小写。2,重新写入的ini文件不能保留原有INI文件的注释。3,重新写入的ini文件不能保持原有的顺序...
    99+
    2023-01-31
    模块 Python configobj
  • Python 模块之fabric
    Fabric是一个Python库和命令行工具,旨在为应用部署和系统管理任务的SSH的流水线式操作,使之更加高效和方便。Fabric提供了一套基本的执行本地和远程shell命令、上传和下载文件的操作,包括一些辅助函数,例如驱动正在运行的用户输...
    99+
    2023-01-31
    模块 Python fabric
  • python之commands模块
    要获得shell命令的输出只需要`cmd`命令就可以了,需要得到命令执行的状态则需要判断$的值, 在Python中有一个模块commands也很容易做到以上的效果.看一下三个函数:1). commands.getstatusoutput(c...
    99+
    2023-01-31
    模块 python commands
  • python模块之subprocess
    subprocess.run() 运行并等待args参数指定的指令完成,返回CompletedProcess实例。 参数:(*popenargs, input=None, capture_output=False, timeout=Non...
    99+
    2023-01-31
    模块 python subprocess
  • Python之Subprocess模块
    前言其实有一个模块也支持执行系统命令,那个模块就是sys.system,但他执行系统命令会直接通过主进程去执行命令,那假如,该命令的执行需要耗费一个小时,那么主进程会卡一个小时,而不会去干别的事,这样就会导致程序的运行效率低下。 如果由su...
    99+
    2023-01-31
    模块 Python Subprocess
  • python之selectors模块
      selectors模块是在python3.4版本中引进的,它封装了IO多路复用中的select和epoll,能够更快,更方便的实现多并发效果。  官方文档见:https://docs.python.org/3/library/...
    99+
    2023-01-31
    模块 python selectors
  • python模块之configparse
    configparser configParser 模块用于操作配置文件 注:Parser汉译为“解析”之意。 配置文件的格式与windows ini文件类似,可以包含一个或多个节(section),每个节可以有多个参数(键=值或者键:值)...
    99+
    2023-01-31
    模块 python configparse
  • python之syslog模块
    syslog模块为提供了rsyslog模块的一个接口。可以记录程序运行时的输出信息。个人认为此方法没有logging模块方便常用方法如下:syslog.open(indent[,logopt[,facility]])  ####初始化rsy...
    99+
    2023-01-31
    模块 python syslog
  • python模块之samba
    本文为记录Python下载samba里的文件的代码:from smb.SMBConnection import SMBConnection def get_script_file(): conn = SMBCon...
    99+
    2023-01-31
    模块 python samba
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作