首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Python从MySQL数据库中删除较旧的数据

使用Python从MySQL数据库中删除较旧的数据
EN

Stack Overflow用户
提问于 2016-02-02 19:16:32
回答 2查看 1.5K关注 0票数 4

我想自动删除超过7天的记录,但它不起作用。消息显示旧数据已删除,但实际上并未删除数据。

我的代码是:

代码语言:javascript
复制
try:
    db= MySQLdb.connect("localhost","root","","testDB")
    cursor=db.cursor()
    sql="DELETE FROM CALLRECORD WHERE DATE< DATE_SUB(NOW(), INTERVAL 7 DAY)"
    try:
        cursor.execute(sql)
        db.commit()
        print "Deleted Older Data from database"

    except:
        db.rollback()
        print "Cann't delete older data"
    db.close()

except:
    print "localserver not connected"
EN

回答 2

Stack Overflow用户

发布于 2016-02-02 19:22:37

我认为你在查询中犯了一个错误,你正在删除过去7天内插入的记录。使用以下查询,而不是您的查询:

代码语言:javascript
复制
DELETE FROM CALLRECORD
WHERE DATE < DATE_SUB(NOW(), INTERVAL 7 DAY)
票数 2
EN

Stack Overflow用户

发布于 2016-02-02 19:23:48

您正在使用>而不是<,因此您将删除新记录而不是旧记录。您需要删除日期早于(而不是晚于)七天前的记录。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35151952

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档