2

我正在使用 Python 和 MySQLdb 向我的数据库添加行。似乎当我的脚本退出时,行被删除了。我在脚本退出前的最后几行在表格上做了一个“select *”,它显示了我的一行。当我重新运行脚本时,第一行(打开连接后)执行相同的“选择 *”并返回零结果。我在这里真的很茫然。我已经为此工作了大约 2 个小时,但无法理解什么可以访问我的数据库。

此外,在运行脚本之间,我从终端手动运行“select *”,结果为零。

如果我从终端手动添加一行,它似乎会持续。

插入行的查询:

cursor.execute("INSERT INTO sessions(username, id, ip) VALUES (%s, %s, %s)", (username, SessionID, IP]))

我用来检查数据的查询:

cursor.execute("select * from sessions")
print cursor.fetchall()

这显示程序退出之前的行,然后在程序再次运行时不显示任何内容。

提前感谢所有帮助。

4

2 回答 2

5

执行查询后,您似乎需要进行connection.commit()更改(替换connection为您的数据库连接变量)。

http://docs.python.org/library/sqlite3.html

Connection.commit():此方法提交当前事务。如果您不调用此方法,则自上次调用 commit() 以来所做的任何事情都不会从其他数据库连接中看到。如果您想知道为什么看不到已写入数据库的数据,请检查您是否忘记调用此方法。

于 2012-08-02T21:03:33.573 回答
0

检查另一个问题:Python MySQLdb 更新查询失败

您可以找到一些关于如何提交、如何使用自动提交进行连接等的示例。

于 2012-08-02T21:05:52.590 回答