在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条。
数据库,连接
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]