在Python中要连接数据库,首先我们得先安装几个重要的东西,主要有:

 (1)Python-dev包

 (2)setuptools-0.6c11.tar.gz

 (3)MySQL-python-1.2.3.tar.gz


下面分别来说说这三个主要的包的安装步骤:

(1)Python-dev包  

直接yum install python-devel

(2)setuptools-0.6c11.tar.gz

    在网上下载后,先解压:tar zxf setuptools-0.6c11.tar.gz,完毕后cd到解压后的文件夹,执行:

  python setup.py build

      python setup.py install


(3)MySQL-python-1.2.3.tar.gz

跟安装setuptools-0.6c11.tar.gz步骤一样,先解压:tar zxfMySQL-python-1.2.3.tar.gz,

完毕后cd到解压后的文件夹,执行:

  python setup.py build

      python setup.py install


在执行上述命令之前,最好先修改一个文件,我们先查找mysql_config的位置,使用命令:

  find / -name mysql_config

然后我们获取到它的路径,我的是:/usr/bin/mysql_config,然后修改MySQL-python-1.2.3目录下

的site.cfg文件,去掉mysql_config=XXX这行前面的#,改为:

  mysql_config = /usr/bin/mysql_config

经过上面的步骤,我们基本就可以MySQLdb安装好了。

可以测试一下,在Python的交互式命令行,输入import MySQLdb,如果没有报错,就说明已经安装好。

下面的Python代码展示了如何连接数据库,并执行数据库的一些操作:

import MySQLdbtry:conn = MySQLdb.connect(host='localhost',user='root',passwd='root',port=3306)cur = conn.cursor()cur.execute('create database if not exists PythonDB')conn.select_db('PythonDB')cur.execute('create table Test(id int,name varchar(20),info varchar(20))')value = [1,'ACdreamer','student']cur.execute('insert into Test values(%s,%s,%s)',value)values = []for i in range(20):values.append((i,'Hello World!','My number is '+str(i)))cur.executemany('insert into Test values(%s,%s,%s)',values)cur.execute('update Test set name="ACdreamer" where id=3')conn.commit()cur.close()conn.close()
except MySQLdb.Error,msg:print "MySQL Error %d: %s" %(msg.args[0],msg.args[1])

可以看出,连接数据库大致分为以下步骤:

(1)建立和数据库系统的连接

(2)获取操作游标

(3)执行SQL,创建一个数据库(当然这一步不是必需的,因为我们可以用已经存在的数据库)

(4)选择数据库

(5)进行各种数据库操作

(6)操作完毕后,提交事务(这一步很重要,因为只有提交事务后,数据才能真正写进数据库)

(7)关闭操作游标

(8)关闭数据库连接

当然,如果我们使用已经存在的数据库,那么在获取连接时就可以制定了,比如:

conn = MySQLdb.connect(host='localhost', user='root', passwd='root', db='PythonDB')


如果数据库中有中文,为了防止乱码,我们加入属性charset = 'uft-8'或者'gb2312',charset要跟数据库的编码一致。

conn = MySQLdb.connect(host='localhost', user='root', 

       passwd='root', db='PythonDB',charset='utf8') 



下面贴一下常用的函数:

数据库连接对事务操作的方法:commit() 提交    rollback() 回滚

cursor用来执行命令的方法:

callproc(self,procname,args)

用来执行存储过程,接收的参数为存储过程名和参数列表,返回值为受影响的行数

execute(self, query, args)

执行单条sql语句,接收的参数为sql语句本身和使用的参数列表,返回值为受影响的行数

executemany(self, query, args)

执行单挑sql语句,但是重复执行参数列表里的参数,返回值为受影响的行数

nextset(self)

移动到下一个结果集

cursor用来接收返回值的方法:

fetchall(self)

接收全部的返回结果行

fetchmany(self, size=None)

接收size条返回结果行.如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据

fetchone(self)

返回一条结果行

scroll(self, value, mode='relative')

移动指针到某一行,如果mode='relative',则表示从当前所在行移动value条,如果 mode='absolute',则表示从结果集的第一行移动value条。

Python数据库的连接相关推荐

  1. python数据库操作——连接SQLite

    python数据库操作--连接SQLite   hello!我是wakeyo_J,每天一个konwledge point,一起学python,让技术无限发散. 连接SQLite python数据库操作 ...

  2. pydev集成mysql_【Python】Windows平台下Python、Pydev连接Mysql数据库

    Mysql数据库是跨平台的,不是说Python一定就要连接Mongodb. Python连接Mysql数据库是非常easy的. 首先,你要配置好Python的开发环境,详见<[Python]Wi ...

  3. python postgresql跨数据库查询_python访问PostgreSQL数据库之连接库Psycopg2

    python访问PostgreSQL数据库之连接库Psycopg2 作者:佣工7001 由于要在python访问PostgreSQL数据库,需要一个符合DB-API的连接库.通过搜索,锁定两个候选库: ...

  4. deepin中mysql数据库的连接_教你如何典雅的用Python连接MySQL数据库

    简介:作者 | Python语音识别不管是机器学习.web开发或者爬虫,数据库都是绕不过去的.那么今天我们就来介绍Python如何Mysql数据库进行连接以及数据的交换.主要分为以下几个方面:什么是数 ...

  5. python如何连接sql server数据库_Python连接SQLServer数据库

    1.安装pymssql (1) 使用pip3 install pymsslq出现下面这个问题: ERROR: Could not build wheels for pymssql which use ...

  6. python查询mysql数据库_python针对mysql数据库的连接、查询、更新、删除操作示例...

    本文实例讲述了python针对mysql数据库的连接.查询.更新.删除操作.分享给大家供大家参考,具体如下: 连接 一 代码 import pymysql # 打开数据库连接 db = pymysql ...

  7. 记录python使用pymysql连接mysql数据库,使用impyla、ibis-framework[impala]连接hive\impala(kerberos)数据库(备以后查阅)

    记录python使用pymysql连接mysql数据库,使用impyla.ibis-framework[impala]连接hive\impala(kerberos)数据库(备以后查阅) 连接mysql ...

  8. python常见数据库的连接方式【游标】及【pandas】数据读取

    本文介绍以下数据库的连接方式,及数据的增删改查 下方中用到的数据,均为随机数据,无实际业务意义. Mysql-游标及pandas连接方式 PostgreSQL-游标及pandas连接方式 Oracle ...

  9. Python MySQL数据库的连接以及基本操作

    Python MySQL数据库的连接以及基本操作 一.数据库的连接 1.直接连接 2.连接池连接 二. 数据库的基本操作 1.执行函数 2.创建数据表 3.删除表 4.插入函数 6.删除函数 7.状态 ...

最新文章

  1. 用什么服务器开发小程序,开发小程序用什么服务器系统
  2. Java虚拟机规范阅读(二)IEEE754简介以及Java虚拟机中的浮点算法
  3. 我来做百科(第二十天) D
  4. 【JS】原生淘宝轮播图实现总结
  5. [XPath] XPath 与 lxml (三)XPath 坐标轴
  6. oracle last_day比较,Oracle的LAST_DAY函数
  7. BZOJ4458: GTY的OJ
  8. nodejs + echarts 图表展示
  9. 星光嵌入式WM8978音频模块发布
  10. 【WLAN】【基础知识】WIFI那些事儿之DFS
  11. Vue中watch监听路由的使用场景
  12. 教你用Python自制拼图小游戏,一起来玩吧
  13. 【目标检测】SSD: Single Shot MultiBox Detector 模型fine-tune和网络架构
  14. python爬虫能爬取微信密码吗_爬虫如何爬取微信公众号文章
  15. Julia发布全功能调试器:4大新功能问世
  16. 神经网络中的遗忘,遗忘的作用
  17. 深圳买房负担全球第一:记得在泡沫破灭前把房子卖掉
  18. 太阳系及银河系尺寸的直观概念
  19. 初识EMC元器件(九)——气体放电管的参数解读及选型应用
  20. Android中文API文档

热门文章

  1. 分布式事务中的Base理论
  2. 分布式缓存Redis介绍
  3. RequestMapping注解的作用
  4. apollo分布式配置中心原理
  5. SpringBoot高级-消息-AmqpAdmin管理组件的使用
  6. activemq使用
  7. java中定时器的使用
  8. RTCStartupDemo:一款极其简单的 WebRTC 入门项目
  9. elasticsearch系列五:搜索详解(查询建议介绍、Suggester 介绍)
  10. 在MySQL中使用explain查询SQL的执行计划