Python数据库的连接实现方法与注意事项
作者:mdxy-dxy 发布时间:2024-01-14 10:51:54
在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 MySQLdb
try:
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条。


猜你喜欢
- 今天,项目经理问我一个问题,问我这里有2000个URL要检查是否能正常打开,其实我是拒绝的,我知道因为要写代码了,正好学了点Python,一
- 本文实例讲述了Python实现将数据框数据写入mongodb及mysql数据库的方法。分享给大家供大家参考,具体如下:主要内容:1、数据框数
- 前几天又有人在我的这篇文章 python项目练习一:即时标记 下留言,关于其中一个闭包和re.sub的使用不太清楚。我在自己的博客上搜索了下
- #!/usr/bin/env pythonimport sockets = socket.socket(socket.AF_PACKET,
- 前言🥂上一篇文章说完MySQL的事务和锁了,这次来详细介绍一下在MySQL中一条更新语句的详细执行流程 (本文无特殊说明均是采用Innodb
- 1.简单检索数据博客内容中student表为:1.1.检索单个列select + 列名 + from + 表名1.2.检索多个列select
- 通过《SQL Server 数据库备份和还原认识和总结(一)》,相信您对数据备份和还原有了一个更深入的认识,在上文中我没有对事务日志做剖析,
- 如下所示:import pandas as pddf = pd.DataFrame([1, 2, 3, 4, 5], index=[10,
- 在使用pytorch的时候,经常会涉及到两种数据格式tensor和ndarray之间的转换,这里总结一下两种格式的转换:1. tensor
- 识别验证码OCR(Optical Character Recognition)即光学字符识别技术,专门用于对图片文字进行识别,并获取文本。字
- 废话不多说,看代码吧!'''待完善。此代码实现了,根据标注文本的属性,数值,位置,及 容差,去判断 设计 和 实测两
- 项目实现利用face++开发一个课堂签到的软件,实现面向摄像头即可完成记录学号、姓名和时间的签到工作。项目架构项目使用场景代码:流程代码,主
- tensorlfow网络模型可视化。baidu了一些方法,现在介绍下我的流程和遇到的问题:配置window7tensorlfow1.5ana
- 本文简单介绍如何使用 Python 的 pyautogui 模块实现鼠标的自动移动以及键盘的自行输入. 该模块不是 Python 自带的,
- 一般常规的我们保存数据为dict类型时,系统会自动帮我们排序;但有时我们想按照输入顺序的key:value保存到dict中,而不想要改变顺序
- python软件免费吗?python是免费的,是自由、开放源码的软件之一,在python官网可以免费下载,使用者可以自由地发布这个软件的拷贝
- 字符串转list数组str = '1,2,3'arr = str.split(',')gpu_ids分配na
- 感谢人类方方面面的创新,今天Web开发已经不需要在如何设计网站上面浪费时间了。框架和库帮助web开发者得以专注于真正的开发工作上。下面的这些
- 利用seek监控文件内容,并打印出变化内容:#/usr/bin/env python#-*- coding=utf-8 -*-pos = 0
- 图例如下https://github.com/Dongvdong/python_Smartvoice上电后,只要周围声音超过 2000,开始