问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

在eclipse上,MySQLdb使用connect方法连接Mysql数据库。报错,求大佬解决

发布网友 发布时间:2022-04-08 18:35

我来回答

2个回答

懂视网 时间:2022-04-08 22:56

如果执行后的输出结果如下所示,意味着你没有安装 MySQLdb 模块:

Traceback (most recent call last):
 File "test.py", line 3, in <module>
 import MySQLdb
ImportError: No module named MySQLdb

安装MySQLdb,请访问 http://sourceforge.net/projects/mysql-python ,(Linux平台可以访问:https://pypi.python.org/pypi/MySQL-python)从这里可选择适合您的平台的安装包,分为预编译的二进制文件和源代码安装包。

如果您选择二进制文件发行版本的话,安装过程基本安装提示即可完成。如果从源代码进行安装的话,则需要切换到MySQLdb发行版本的顶级目录,并键入下列命令:

$ gunzip MySQL-python-1.2.2.tar.gz
$ tar -xvf MySQL-python-1.2.2.tar
$ cd MySQL-python-1.2.2
$ python setup.py build
$ python setup.py install

注意:请确保您有root权限来安装上述模块。


数据库连接

连接数据库前,请先确认以下事项:

  • 您已经创建了数据库 TESTDB.
  • 在TESTDB数据库中您已经创建了表 EMPLOYEE
  • EMPLOYEE表字段为 FIRST_NAME, LAST_NAME, AGE, SEX 和 INCOME。
  • 连接数据库TESTDB使用的用户名为 "testuser" ,密码为 "test123",你可以可以自己设定或者直接使用root用户名及其密码,Mysql数据库用户授权请使用Grant命令。
  • 在你的机子上已经安装了 Python MySQLdb 模块。
  • 如果您对sql语句不熟悉,可以访问我们的 SQL基础教程
  • 实例:

    以下实例链接Mysql的TESTDB数据库:

    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    
    import MySQLdb
    
    # 打开数据库连接
    db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )
    
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
    
    # 使用execute方法执行SQL语句
    cursor.execute("SELECT VERSION()")
    
    # 使用 fetchone() 方法获取一条数据库。
    data = cursor.fetchone()
    
    print "Database version : %s " % data
    
    # 关闭数据库连接
    db.close()

    执行以上脚本输出结果如下:

    Database version : 5.0.45

    创建数据库表

    如果数据库连接存在我们可以使用execute()方法来为数据库创建表,如下所示创建表EMPLOYEE:

    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    
    import MySQLdb
    
    # 打开数据库连接
    db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )
    
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
    
    # 如果数据表已经存在使用 execute() 方法删除表。
    cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
    
    # 创建数据表SQL语句
    sql = """CREATE TABLE EMPLOYEE (
      FIRST_NAME CHAR(20) NOT NULL,
      LAST_NAME CHAR(20),
      AGE INT, 
      SEX CHAR(1),
      INCOME FLOAT )"""
    
    cursor.execute(sql)
    
    # 关闭数据库连接
    db.close()

    数据库插入操作

    以下实例使用执行 SQL INSERT 语句向表 EMPLOYEE 插入记录:

    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    
    import MySQLdb
    
    # 打开数据库连接
    db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )
    
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
    
    # SQL 插入语句
    sql = """INSERT INTO EMPLOYEE(FIRST_NAME,
      LAST_NAME, AGE, SEX, INCOME)
      VALUES (‘Mac‘, ‘Mohan‘, 20, ‘M‘, 2000)"""
    try:
     # 执行sql语句
     cursor.execute(sql)
     # 提交到数据库执行
     db.commit()
    except:
     # Rollback in case there is any error
     db.rollback()
    
    # 关闭数据库连接
    db.close()

    以上例子也可以写成如下形式:

    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    
    import MySQLdb
    
    # 打开数据库连接
    db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )
    
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
    
    # SQL 插入语句
    sql = "INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) VALUES (‘%s‘, ‘%s‘, ‘%d‘, ‘%c‘, ‘%d‘ )" % (‘Mac‘, ‘Mohan‘, 20, ‘M‘, 2000)
    try:
     # 执行sql语句
     cursor.execute(sql)
     # 提交到数据库执行
     db.commit()
    except:
     # 发生错误时回滚
     db.rollback()
    
    # 关闭数据库连接
    db.close()

    实例:

    以下代码使用变量向SQL语句中传递参数:

    ..................................
    user_id = "test123"
    password = "password"
    
    con.execute(‘insert into Login values("%s", "%s")‘ %  (user_id, password))
    ..................................

    数据库查询操作

    Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据。

  • fetchone(): 该方法获取下一个查询结果集。结果集是一个对象
  • fetchall():接收全部的返回结果行.
  • rowcount: 这是一个只读属性,并返回执行execute()方法后影响的行数。
  • 实例:

    查询EMPLOYEE表中salary(工资)字段大于1000的所有数据:

    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    
    import MySQLdb
    
    # 打开数据库连接
    db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )
    
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
    
    # SQL 查询语句
    sql = "SELECT * FROM EMPLOYEE WHERE INCOME > ‘%d‘" % (1000)
    try:
     # 执行SQL语句
     cursor.execute(sql)
     # 获取所有记录列表
     results = cursor.fetchall()
     for row in results:
     fname = row[0]
     lname = row[1]
     age = row[2]
     sex = row[3]
     income = row[4]
     # 打印结果
     print "fname=%s,lname=%s,age=%d,sex=%s,income=%d" %  (fname, lname, age, sex, income )
    except:
     print "Error: unable to fecth data"
    
    # 关闭数据库连接
    db.close()

    以上脚本执行结果如下:

    fname=Mac, lname=Mohan, age=20, sex=M, income=2000

    数据库更新操作

    更新操作用于更新数据表的的数据,以下实例将 TESTDB表中的 SEX 字段全部修改为 ‘M‘,AGE 字段递增1:

    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    
    import MySQLdb
    
    # 打开数据库连接
    db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )
    
    # 使用cursor()方法获取操作游标 
    cursor = db.cursor()
    
    # SQL 更新语句
    sql = "UPDATE EMPLOYEE SET AGE = AGE + 1
        WHERE SEX = ‘%c‘" % (‘M‘)
    try:
     # 执行SQL语句
     cursor.execute(sql)
     # 提交到数据库执行
     db.commit()
    except:
     # 发生错误时回滚
     db.rollback()
    
    # 关闭数据库连接
    db.close()

    执行事务

    事务机制可以确保数据一致性。

    事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。

  • 原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。
  • 一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
  • 隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
  • 持久性(durability)。持续性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。
  • Python DB API 2.0 的事务提供了两个方法 commit 或 rollback。

    实例:

    # SQL删除记录语句
    sql = "DELETE FROM EMPLOYEE WHERE AGE > ‘%d‘" % (20)
    try:
     # 执行SQL语句
     cursor.execute(sql)
     # 向数据库提交
     db.commit()
    except:
     # 发生错误时回滚
     db.rollback()

    对于支持事务的数据库, 在Python数据库编程中,当游标建立之时,就自动开始了一个隐形的数据库事务。

    commit()方法游标的所有更新操作,rollback()方法回滚当前游标的所有操作。每一个方法都开始了一个新的事务。


    错误处理

    DB API中定义了一些数据库操作的错误及异常,下表列出了这些错误和异常:

    异常描述
    Warning 当有严重警告时触发,例如插入数据是被截断等等。必须是 StandardError 的子类。
    Error 警告以外所有其他错误类。必须是 StandardError 的子类。
    InterfaceError 当有数据库接口模块本身的错误(而不是数据库的错误)发生时触发。 必须是Error的子类。
    DatabaseError 和数据库有关的错误发生时触发。 必须是Error的子类。
    DataError 当有数据处理时的错误发生时触发,例如:除零错误,数据超范围等等。 必须是DatabaseError的子类。
    OperationalError 指非用户控制的,而是操作数据库时发生的错误。例如:连接意外断开、 数据库名未找到、事务处理失败、内存分配错误等等操作数据库是发生的错误。 必须是DatabaseError的子类。
    IntegrityError 完整性相关的错误,例如外键检查失败等。必须是DatabaseError子类。
    InternalError 数据库的内部错误,例如游标(cursor)失效了、事务同步失败等等。 必须是DatabaseError子类。
    ProgrammingError 程序错误,例如数据表(table)没找到或已存在、SQL语句语法错误、 参数数量错误等等。必须是DatabaseError的子类。
    NotSupportedError 不支持错误,指使用了数据库不支持的函数或API等。例如在连接对象上 使用.rollback()函数,然而数据库并不支持事务或者事务已关闭。 必须是DatabaseError的子类。

    转自:http://www.runoob.com/python/python-mysql.html

    Mysqldb连接Mysql数据库(转)

    标签:

    热心网友 时间:2022-04-08 20:04

    更多的代码贴出来。帮你解决。。
    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    绿茶要猛冲吗,绿茶鲜嫩不需要(绿茶冲泡的正确方式) 绿茶为什么越好越不耐泡 绿茶要泡几泡?哪种绿茶最耐泡? 哪种绿茶最耐泡 职场故事:美女职员遇到暴躁老板 老板脾气坏得要命,我该怎么办 老板老爱发脾气,我们应该怎么做呀? 害怕老总发脾气怎么办 网络上用名字测和另一个人的关系准确吗 一个男生把自己的名字和另一个人的名字放在一起,中间放个"&amp;"符号... 一加7Pro相机顺拍怎么设置? 一加7Pro能够使用自定义屏幕分辨率吗? 一加7pro截图发微信朋友圈模糊怎么办 一加7Pro支持设置自定义屏幕分辨率吗? 一加7Pro怎么使用自定义屏幕分辨率呢? 一加7Pro自定义屏幕分辨率的设置方法? 京东业务单号是哪个? 京东上买的东西,但商家发的是邮政,那快递单号是不是那商户单号呢? 怎样申诉征信不良? 征信修复都需要什么东西?申诉流程是什么?逾期连三累六说的是连续三个月有欠款么? 单号指的是什么啊? 怎样分别固态硬盘是新的还是旧的 扫二维码支付商户单号1701551906976613是什么商家 净增效益原则对于公司金融的意义 怎么检测固态硬盘是不是全新 沙盘模拟与现实的区别 财务报表问题 基金是长投还是短投好呢 如何解读财务报表 笔记本换好的固态硬盘怎么看新换的固态硬盘是不是新的 win7无线适配器或访问点有问题怎么办 win7系统,无线网络连不上,显示无线适配器或访问点有问题,怎么办? 电脑连接wfif是显示无线适配器或访问点有问题是怎么回事,我可以连接我手机的热点,连接路由器却不可 我的电脑无线总是上半小时到一小时就自动断网,提示我的无线适配器或访问点有问题,求大神帮助解决!! 无法连接路由器,显示无线适配器或访问点有问题怎么办 无线适配器或访问点有问题连不上无线? 微信查询名下实名账号安全吗 微信被盗,但没绑定银行卡,在微信里的查询名下账户会泻漏银行卡信息吗?我用新微信查询,却写查询失败 微信被盗,微信里的查询名下帐户会泻漏银行卡信息吗?被盗的没有绑定银行卡,但新微信绑定了,会泻漏吗? 微信名下绑卡账户是什么意思具体是什么意思 为什么我的绑卡账户下面有陌生人 可以给个详细的解释吗? 企业库企业黄页里的信息怎么取消 我在百度黄页上登记了我厂的信息 现在想删除 可是怎么也删除不了 有没有电脑高手会删除百度黄页和快照的 帮帮我 急 如何删除公司黄页信息? 怎样才能去掉黄页上免费发布的信息 怎样删除自己黄页88网上的信息 联系人在黄页中设置着,怎么删除? 我的黄页88里发布的信息审核通过了,在百度里可以搜得到,现在想把它删除掉,不让别人搜到,请问怎么删? 生活黄页如何删除 怎样删除发布在中国黄页网的信息啊