mysql-Python数据库的连接

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安装好了。


注:若系统中查找不到mysql_config则需要安装

libmysqld-dev

libmysqlclient-dev


两个文件即可


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



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

[python] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. import MySQLdb  
  2.   
  3. try:  
  4.     conn = MySQLdb.connect(host='localhost',user='root',passwd='root',port=3306)  
  5.     cur = conn.cursor()  
  6.   
  7.     cur.execute('create database if not exists PythonDB')  
  8.     conn.select_db('PythonDB')  
  9.     cur.execute('create table Test(id int,name varchar(20),info varchar(20))')  
  10.   
  11.     value = [1,'ACdreamer','student']  
  12.     cur.execute('insert into Test values(%s,%s,%s)',value)  
  13.   
  14.     values = []  
  15.     for i in range(20):  
  16.         values.append((i,'Hello World!','My number is '+str(i)))  
  17.   
  18.     cur.executemany('insert into Test values(%s,%s,%s)',values)  
  19.     cur.execute('update Test set name="ACdreamer" where id=3')  
  20.   
  21.     conn.commit()  
  22.     cur.close()  
  23.     conn.close()  
  24. except MySQLdb.Error,msg:  
  25.     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条。


没有更多推荐了,返回首页