zoukankan      html  css  js  c++  java
  • python连接mysql

    (1)pyhton shell下导入MySQLdb失败。
    http://pypi.python.org/pypi/MySQL-python/
    (2)下载解压MySQL-python。
    http://pypi.python.org/packages/source/M/MySQL-python/MySQL-python-1.2.3.tar.gz

    安装: python setup.py build  && python setup.py install

    buid出错缺少setuptools,如下:
    Traceback (most recent call last):
      File "setup.py", line 5, in <module>
        from setuptools import setup, Extension
    ImportError: No module named setuptools

    (4)下载安装setuptools。
    http://pypi.python.org/pypi/setuptools    #downloads 选自己Python对应的版本。

    python setup.py build  && python setup.py install
    root@192.168.1.104:~/software/python# python
    Python 2.6.6 (r266:84292, Jun 18 2012, 14:10:23)
    [GCC 4.4.6 20110731 (Red Hat 4.4.6-3)] on linux2
    Type "help", "copyright", "credits" or "license" for more information.
    >>> import setuptools

    上面没有报错说明安装setuptools成功了的。
    (5)安装 mysql-devel 及其他必要的库
    yum install mysql mysql-devel

    (6)build mysqldb
    cd MySQL-python-1.2.3
    /MySQL-python-1.2.3# python setup.py build
    实践出现:
    在包含自 _mysql.c:29 的文件中:
    pymemcompat.h:10:20: 错误:Python.h:没有那个文件或目录

    继续执行python setup.py install,可能出现以下错误:
               ======> pymemcompat.h:10:20: 致命错误:Python.h:没有那个文件或目录 编译中断。
              出现这个问题的原因是,系统中的python是自带的,而没有安装python的开发包并没有安装,所以在shell下执行如下命令:
    点击(此处)折叠或打开
    yum install python-devel
    Installed size: 454 k
    Is this ok [y/N]: y
    Installed:
      python-devel.i686 0:2.6.6-29.el6_2.2  Complete!

      再次:
    python setup.py build

    出错:
    编辑 site.cfg ,把 mysql_config 那一行取消注释,并改为:
    mysql_config = ”mysql_config的路径“(locate mysql_config。查找到mysql_config的路径)
    python setup.py build
    python setup.py install

    出错:

      找不到setuptools;

      对应操作:

          1、python2.6 ,导入sys模块。

          2、print sys.path

                             将sys.path下增加一个软链接。该链接指向settools中的setup.py
    安装:python setup.py install
    Finished processing dependencies for MySQL-python==1.2.3

    安装结束后,
    打开 python2.6  输入
    import MySQLdb   (注意:MySQLdb中的y是小写)
    如果没够报错就说明安装成功了。

    下面是一个批量导入数据到数据库的例子(myql.py):

     1 #!/usr/bin/env python2.6
     2 #encoding=utf-8
     3 
     4 import MySQLdb
     5 
     6 try:
     7     conn = MySQLdb.connect(host='10.10.13.162', user = 'root', passwd='123456',port=3306, charset='utf8')
     8 
     9     #使用cursor()方法获取操作游标
    10     cur = conn.cursor()
    11     conn.select_db('weixin')
    12 
    13     values = []
    14     file_object = open('./aa.txt', 'r')
    15     i = 2 
    16     for eachLine in file_object.readlines():
    17         tt = eachLine.strip()
    18         i = i+1 
    19         values.append((i, tt))
    20     cur.executemany('insert into test values(%s, %s)', values)
    21                 
    22     conn.commit()
    23     cur.close()
    24     conn.close()
    25 except MySQLdb.Error, e:
    26     print 'error'

     执行:python2.6   mysql.py

     1 #!/usr/bin/env python
     2 #coding=utf-8
     3 ######################################
     4 #
     5 # @author migle
     6 # @date 2010-01-17
     7 #
     8 ######################################
     9 #
    10 # MySQLdb 查询
    11 #
    12 #######################################
    13 
    14 import MySQLdb
    15 
    16 conn = MySQLdb.connect(host='localhost', user='root', passwd='longforfreedom',db='python')
    17 
    18 cursor = conn.cursor()
    19 
    20 count = cursor.execute('select * from test')
    21 
    22 print '总共有 %s 条记录',count
    23 
    24 #获取一条记录,每条记录做为一个元组返回
    25 print "只获取一条记录:"
    26 result = cursor.fetchone();
    27 print result
    28 #print 'ID: %s   info: %s' % (result[0],result[1])
    29 print 'ID: %s   info: %s' % result 
    30 
    31 #获取5条记录,注意由于之前执行有了fetchone(),所以游标已经指到第二条记录了,也就是从第二条开始的所有记录
    32 print "只获取5条记录:"
    33 results = cursor.fetchmany(5)
    34 for r in results:
    35     print r
    36 
    37 print "获取所有结果:"
    38 #重置游标位置,0,为偏移量,mode=absolute | relative,默认为relative,
    39 cursor.scroll(0,mode='absolute')
    40 #获取所有结果
    41 results = cursor.fetchall()
    42 for r in results:    
    43     print r    #结果是元组类型,注意
    44 cursor.close()
    45 conn.close()    
  • 相关阅读:
    Leetcode题目practice
    文件操作
    39个奇葩代码注释,拿走不谢
    Spring Boot 之配置导入,强大到不行!
    Git 的这个神技,学会爽歪歪~
    同事天天写垃圾代码,就没办法?
    for (;;) 与 while (true),哪个更快?
    Spring Boot 怎么打一个可执行 Jar 包?
    程序员真的是太太太太太太太太难了!
    面试官:new一个对象有哪两个过程?
  • 原文地址:https://www.cnblogs.com/chris-cp/p/3712333.html
Copyright © 2011-2022 走看看