[Python]使用MYSQL
MYSQLdb是Python中用来操作MYSQL数据库的包
地址:http://sourceforge.net/projects/mysql-python/
MYSQLdb安装
windows下是一键安装的EXE版本号。Linux下需手动安装,安装过程碰到一些问题,这里简单叙述下Linux下的安装.
wget http://XXX#下载
tar zvxf XXX.tar.gz#解压
cd XXX/#进入目录
Python setup.py build#报错
错误为:can not find mysql_config
要配置mysql的參数。
find / -name mysql_config#从根文件夹開始寻找mysql_config文件
找到,则编辑之前文件site.py:
mysql_config = /usr/bin/XXX
找不到,要下载这两个包:libmysqld-dev,libmysqlclient-dev
sudo apt-get install ibmysqld-dev
sudo apt-get install libmysqlclient-dev
再改动site.py:
mysql_config.path="/usr/bin/mysql_config"
继续执行:
Python setup.py build#报错
错误为:command ‘gcc’failed with exit status 1
继续安装这两个包:build-essential,python-dev
sudo apt-get install build-essential
sudo apt-get install python-dev
继续执行:
Python setup.py build
python setup.py install
(參考blog : http://blog.163.com/rettar@126/blog/static/1216503422012626105639255/ )
MYSQLdb 使用
MYSQLdb的文档少的可怜,sourceforge上仅仅有一个英文的简单介绍,好多功能都自己试出来的。
英文文档:http://sourceforge.net/p/mysql-python/mysqldb-2/ci/default/tree/doc/MySQLdb.txt#l61
简单操作:
导入包
import MYSQLdb
建立连接
conn = MySQLdb.connect(host=‘192.168.1.108‘, user=‘mdx‘, passwd=‘med‘, db=‘mydb‘, port=3306, charset="utf8")
建立游标对象
cursor = conn.cursor()
运行
sql = ‘select %^*$^&^’
cursor.execute(sql)
获取返回信息
results = cursor.fetchall()
#这里的results是列表,数据库中一行信息为列表中的一个元组。
參数形式输入
sql = ‘insert into table1 (id, name) values(%s%s)’
param = (10, ‘huang’)
cursor.execute(sql, param)
*注意,不管何种參数,占位符均为%s,param能够使元组,或者数组
批量插入数据
sql = ‘insert into table1 (id, name) values(%s%s)’
param = [(10, ‘huang’), (20, ‘li‘)...]
cursor.executemany(sql, param)
*这里param每一个元素为一个元组,param自身能够使元组,或者数组
关闭连接
cursor.close()
conn.close()
游标和连接都要关闭
导出数据
在本地机上写好的数据库,要放到server端,使用导入和导出,实现这个功能。
首先,本地机上导出数据库为.sql格式:
能够用mysql workbench 图形化界面,也能够使用命令行。
mysqldump -uroot -p(password) -h127.0.0.1 database1 > mydb.sql
得到mydb.sql的导出文件
使用FTP把sql文件传到server
再在server上导入sql文件:
mysql -uroot -p(password) -h127.0.0.1;
mysql > create database mydb#创建新数据库
mysql > source mydb.sql#导入sql文件
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。