Linux下使⽤Python操作MySQL数据库
安装mysql-python
1、下载mysql-python
打开终端:
cd /usr/local
2、解压
sudo tar -zxvf MySQL-python-1.2.
cd MySQL-python-1.2.2
3、在安装前需进⾏配置
a、修改setup_posix.py中的mysql_config.path为你mysql安装⽬录的mysql_config路径
b、修改site.cfg中的threadsafe = False,去掉mysql_config前的注释,并改为mysql_config = /usr/local/mysql/bin/mysql_config
c、执⾏命令:
export LD_LIBRARY_PATH=/usr/local/mysql/lib/mysql
sudo ln -s /usr/local/mysql/lib/mysql/libmysqlclient.so /usr/lib/libmysqlclient.so.14
sudo ldconfig (这个很重要,否则后⾯会报错ImportError: libmysqlclient.so.14: cannot open shared object file)
4、编译安装
1)python setup.py build
若未成功的话,需⼿动安装setuptools:
sudo apt-get install python-setuptools
2)sudo python setup.py install
5、测试
python
>>> import MySQLdb
没有错误,则表⽰安装成功了。
使⽤python操作MySQL
使⽤python连接MySQL,创建数据库,创建表格,插⼊/查询数据。python_mysql.py代码如下:
#!/usr/bin/python
# coding: utf-8
import MySQLdb
#连接
cxn = MySQLdb.Connect(host = '127.0.0.1', user = 'root', passwd = 'root')
#游标
cur = cxn.cursor()
try:
except Exception as e:
print(e)
finally:
pass
#创建数据库
#创建表
#插⼊
#查询
for row in cur.fetchall():
print('%s\t%s' %row)
#关闭
cur.close()
cxnmit()
cxn.close()
效果如图:
若出现类似于此的警告:
/usr/local/lib/python2.6/dist-packages/MySQL_python-1.2./MySQLdb/__init__.py:34: DeprecationWarning: the sets module is deprecated from sets import ImmutableSet
解决办法如下:
到上⾯路径MySQLdb下的__init__.py⽂件
1) 在⽂件中 "__init__.py"中,注释掉:
from sets import ImmutableSet
class DBAPISet(ImmutableSet):
新增:
class DBAPISet(frozenset):
2) 在⽂件"converters.py"中,注释掉 from sets import BaseSet, Set 这⼀句话。
3) 在⽂件"converters.py"中,修改其中的"Set" 成为 "set" ( 只有两个地⽅需要修改,即⼤写改⼩写)
⼤概 line 45: return Set([ i for i in s.split(',') if i ]) 改为 return set([ i for i in s.split(',') if i ])
⼤概 line 129: Set: Set2Str, 改为 set: Set2Str,
附MySQLdb的相关资料
1.引⼊MySQLdb库
import MySQLdb
mysql下载下来没安装包2.和数据库建⽴连接
t(host="localhost",user="root",passwd="sa",db="mytable",charset="utf8")
提供的connect⽅法⽤来和数据库建⽴连接,接收数个参数,返回连接对象.
⽐较常⽤的参数包括
host:数据库主机名.默认是⽤本地主机.
user:数据库登陆名.默认是当前⽤户.
passwd:数据库登陆的秘密.默认为空.
db:要使⽤的数据库名.没有默认值.
port:MySQL服务使⽤的TCP端⼝.默认是3306.
charset:数据库编码.
然后,这个连接对象也提供了对事务操作的⽀持,标准的⽅法
commit() 提交
rollback() 回滚
3.执⾏sql语句和接收返回值
cursor=conn.cursor()
ute(sql,param)
⾸先,我们⽤使⽤连接对象获得⼀个cursor对象,接下来,我们会使⽤cursor提供的⽅法来进⾏⼯作.这些⽅法包括两⼤类:1.执⾏命令,2.接收返回值
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条.
下⾯的代码是⼀个完整的例⼦.
#使⽤sql语句,这⾥要接收的参数都⽤%s占位符.要注意的是,⽆论你要插⼊的数据是什么类型,占位符永远都要⽤%s
sql="insert into cdinfo values(%s,%s,%s,%s,%s)"
#param应该为tuple或者list
param=(title,singer,imgurl,url,alpha)
#执⾏,如果成功,n的值为1
ute(sql,param)
#再来执⾏⼀个查询的操作
#我们使⽤了fetchall这个⽅法.这样,cds⾥保存的将会是查询返回的全部结果.每条结果都是⼀个tuple类型的数据,这些tuple组成了⼀个tuple
cds=cursor.fetchall()
#因为是tuple,所以可以这样使⽤结果集
print cds[0][3]
#或者直接显⽰出来,看看结果集的真实样⼦
print cds
#如果需要批量的插⼊数据,就这样做
sql="insert into cdinfo values(0,%s,%s,%s,%s,%s)"
#每个值的集合为⼀个tuple,整个参数集组成⼀个tuple,或者list
param=((title,singer,imgurl,url,alpha),(title2,singer2,imgurl2,url2,alpha2)) #使⽤executemany⽅法来批量的插⼊数据.这真是⼀个很酷的⽅法!
utemany(sql,param)
4.关闭数据库连接
需要分别的关闭指针对象和连接对象.他们有名字相同的⽅法cursor.close()
conn.close()
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论