平时的主要编程语言是Java,开发时也主要用Mysql,经常为了测试,调试的目的需要操作数据库,比如备份,插入测试数据,修改测试数据,有些 时候不能简单的用SQL就能完成任务,或都很好的完成任务,用Java写又有点太麻烦了,就想到了Python。Python语法简洁,不用编译,可以经 较好的完成任务。今天看了下Python对Mysql的操作,做一下记录。
首先,安装需要的环境,Mysql和Python就不说了,必备的东西。
主要是安装的MySQLdb,可以去sf.net下载,具体地址是http://sourceforge.net/projects/mysql-python/
如果用Ubuntu,直接
sudo apt-get install python-mysqldb
安装完成之后可以在Python解释器中测试一下
输入
- import MySQLdb #注意大小写!!
- import MySQLdb #注意大小写!!
如果不报错,就证明安装成功了,可能继续了
MySQLdb在Python中也就相当于JAVA中的MySQL的JDBC Driver,Python也有类似的数据接口规范Python DB API,MySQLdb就是Mysql的实现。操作也比较简单和其它平台或语言操作数据库一样,就是建立和数据库系统的连接,然后给数据库输入SQL,再 从数据库获取结果。
先写一个最简单的,创建一个数据库:
- #!/usr/bin/env python
- #coding=utf-8
- ###################################
- # @author migle
- # @date 2010-01-17
- ##################################
- #MySQLdb 示例
- #
- ##################################
- import MySQLdb
- #建立和数据库系统的连接
- conn = MySQLdb.connect(host='localhost', user='root',passwd='longforfreedom')
- #获取操作游标
- cursor = conn.cursor()
- #执行SQL,创建一个数据库.
- cursor.execute("""create database python """)
- #关闭连接,释放资源
- cursor.close();
- #!/usr/bin/env python
- #coding=utf-8
- ###################################
- # @author migle
- # @date 2010-01-17
- ##################################
- #MySQLdb 示例
- #
- ##################################
- import MySQLdb
- #建立和数据库系统的连接
- conn = MySQLdb.connect(host='localhost', user='root',passwd='longforfreedom')
- #获取操作游标
- cursor = conn.cursor()
- #执行SQL,创建一个数据库.
- cursor.execute("""create database python """)
- #关闭连接,释放资源
- cursor.close();
创建数据库,创建表,插入数据,插入多条数据
- #!/usr/bin/env python
- #coding=utf-8
- ###################################
- # @author migle
- # @date 2010-01-17
- ##################################
- #MySQLdb 示例
- #
- ##################################
- import MySQLdb
- #建立和数据库系统的连接
- conn = MySQLdb.connect(host='localhost', user='root',passwd='longforfreedom')
- #获取操作游标
- cursor = conn.cursor()
- #执行SQL,创建一个数据库.
- cursor.execute("""create database if not exists python""")
- #选择数据库
- conn.select_db('python');
- #执行SQL,创建一个数据表.
- cursor.execute("""create table test(id int, info varchar(100)) """)
- value = [1,"inserted ?"];
- #插入一条记录
- cursor.execute("insert into test values(%s,%s)",value);
- values=[]
- #生成插入参数值
- for i in range(20):
- values.append((i,'Hello mysqldb, I am recoder ' + str(i)))
- #插入多条记录
- cursor.executemany("""insert into test values(%s,%s) """,values);
- #关闭连接,释放资源
- cursor.close();
- #!/usr/bin/env python
- #coding=utf-8
- ###################################
- # @author migle
- # @date 2010-01-17
- ##################################
- #MySQLdb 示例
- #
- ##################################
- import MySQLdb
- #建立和数据库系统的连接
- conn = MySQLdb.connect(host='localhost', user='root',passwd='longforfreedom')
- #获取操作游标
- cursor = conn.cursor()
- #执行SQL,创建一个数据库.
- cursor.execute("""create database if not exists python""")
- #选择数据库
- conn.select_db('python');
- #执行SQL,创建一个数据表.
- cursor.execute("""create table test(id int, info varchar(100)) """)
- value = [1,"inserted ?"];
- #插入一条记录
- cursor.execute("insert into test values(%s,%s)",value);
- values=[]
- #生成插入参数值
- for i in range(20):
- values.append((i,'Hello mysqldb, I am recoder ' + str(i)))
- #插入多条记录
- cursor.executemany("""insert into test values(%s,%s) """,values);
- #关闭连接,释放资源
- cursor.close();
查询和插入的流程差不多,只是多了一个得到查询结果的步骤
- #!/usr/bin/env python
- #coding=utf-8
- ######################################
- #
- # @author migle
- # @date 2010-01-17
- #
- ######################################
- #
- # MySQLdb 查询
- #
- #######################################
- import MySQLdb
- conn = MySQLdb.connect(host='localhost', user='root', passwd='longforfreedom',db='python')
- cursor = conn.cursor()
- count = cursor.execute('select * from test')
- print '总共有 %s 条记录',count
- #获取一条记录,每条记录做为一个元组返回
- print "只获取一条记录:"
- result = cursor.fetchone();
- print result
- #print 'ID: %s info: %s' % (result[0],result[1])
- print 'ID: %s info: %s' % result
- #获取5条记录,注意由于之前执行有了fetchone(),所以游标已经指到第二条记录了,也就是从第二条开始的所有记录
- print "只获取5条记录:"
- results = cursor.fetchmany(5)
- for r in results:
- print r
- print "获取所有结果:"
- #重置游标位置,0,为偏移量,mode=absolute | relative,默认为relative,
- cursor.scroll(0,mode='absolute')
- #获取所有结果
- results = cursor.fetchall()
- for r in results:
- print r
- conn.close()
- #!/usr/bin/env python
- #coding=utf-8
- ######################################
- #
- # @author migle
- # @date 2010-01-17
- #
- ######################################
- #
- # MySQLdb 查询
- #
- #######################################
- import MySQLdb
- conn = MySQLdb.connect(host='localhost', user='root', passwd='longforfreedom',db='python')
- cursor = conn.cursor()
- count = cursor.execute('select * from test')
- print '总共有 %s 条记录',count
- #获取一条记录,每条记录做为一个元组返回
- print "只获取一条记录:"
- result = cursor.fetchone();
- print result
- #print 'ID: %s info: %s' % (result[0],result[1])
- print 'ID: %s info: %s' % result
- #获取5条记录,注意由于之前执行有了fetchone(),所以游标已经指到第二条记录了,也就是从第二条开始的所有记录
- print "只获取5条记录:"
- results = cursor.fetchmany(5)
- for r in results:
- print r
- print "获取所有结果:"
- #重置游标位置,0,为偏移量,mode=absolute | relative,默认为relative,
- cursor.scroll(0,mode='absolute')
- #获取所有结果
- results = cursor.fetchall()
- for r in results:
- print r
- conn.close()
相关推荐
### 课题-Python-MySQLdb-学习总结 #### 概述 在当今信息化时代,几乎所有的应用程序都需要与数据打交道。Python作为一种广泛使用的编程语言,其生态中存在多种用于操作数据库的库,其中`MySQLdb`是针对MySQL数据库...
Python中的MySQLdb模块是用于与MySQL数据库交互的重要工具,它实现了Python数据库API规范,使得Python程序员可以方便地在Python程序中执行SQL语句并处理数据库操作。以下是对MySQLdb模块的一些关键知识点的详细说明...
MySQL-python(也称为PyMySQL)是一个Python DB-API 2.0兼容的MySQL客户端库。它实现了Python应用程序与MySQL服务器之间的通信协议,使得Python代码可以发送SQL查询、处理结果并执行其他数据库操作。在本例中,版本...
首先,MySQL-python库,也称为`MySQLdb`,是基于`_mysql`这个C语言编写的MySQL客户端库进行封装的。它提供了Python标准DB API 2.0的实现,使得在Python中操作MySQL数据库变得简单而直观。这个API包括了连接数据库、...
- 配置文件`site.cfg`可以用来指定MySQL客户端库的位置,以解决找不到库文件的问题。 5. **测试安装**: - 安装完成后,启动Python解释器,尝试导入`MySQLdb`模块。如果能正常导入且无异常,说明安装成功。 6. *...
安装MySQL-python-1.2.4b4.win32-py2.7.exe时,用户需要确保已经安装了Python 2.7版本,并且系统上没有其他冲突的MySQL客户端库。一旦安装成功,可以通过在Python环境中导入`MySQLdb`模块来开始使用它。例如: ```...
MySQLdb主要依赖于MySQL的Connector/C库(即C语言编写的MySQL客户端库)和Python的ctypes库。因此,在离线安装MySQLdb之前,确保系统已经安装了Python2和ctypes库,以及MySQL的C库。 1. **获取MySQLdb的安装包**:...
这是因为系统中缺少`libmysqlclient-dev`包,它是MySQL客户端库的开发文件。为了继续安装,你需要运行: ```bash sudo apt-get install libmysqlclient-dev ``` 安装完成后,重新尝试`pip install mysql-python`,...
在使用`MySQLdb`之前,还需要确保已经安装了MySQL服务器和客户端,以及在Python环境中安装了`MySQLdb`库本身。你可以使用pip来安装,命令如下: ``` pip install mysqlclient ``` 或者,如果你的系统中已经有旧版本...
MySQL-python是Python编程语言中用于连接MySQL数据库的一个模块,它也被称为`pymysql`或者`MySQLdb`。这个模块允许Python程序员方便地与MySQL服务器进行交互,执行SQL查询,处理数据库事务等操作。在Windows 10 64位...
Python 2.6 是 Python 编程语言的一个早期版本,发布于2008年,而MySQLdb是Python中用于连接MySQL数据库的一个模块,它提供了Python标准库DB-API(PEP 249)接口。在Python 2.6集成mysqldb的完整包中,用户可以利用...
PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。 PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。
本文将详细介绍如何在CentOS 5.5 x86系统上搭建Python数据库访问环境,包括Python的安装、MySQL开发环境的配置以及Oracle客户端的安装。 #### 二、Python环境的安装与配置 在开始安装`MySQLdb`和`cx_Oracle`之前,...
**PyMySQL:纯Python MySQL客户端** PyMySQL是一个Python数据库连接器,它提供了与MySQL数据库进行交互的功能。作为纯Python实现,PyMySQL可以在任何支持Python的平台上使用,无需编译或其他依赖,这使得它成为...
打开命令行窗口,输入`python`进入Python环境,然后尝试导入MySQLdb模块,如`import MySQLdb`。如果没有报错,说明安装成功。 6. 使用说明.txt文件可能会包含更多关于如何使用MySQL-Python库进行数据库操作的指南,...
### 非MySQL环境下安装MySQL-python详解 #### 一、引言 在开发环境中,有时候我们使用的数据库并非标准的MySQL数据库,而是其他兼容MySQL协议的数据库系统,如SGRDB等。在这种情况下,如果需要使用Python操作这些...