1

我正在尝试从代码将新记录插入SQLite数据库。Python

  con = sqlite.connect(connectionString)
  cur = con.cursor()
  countOfNewItems = 0
  for ...
    try:
      con.execute("insert or ignore into items ...")
      countOfNewItems += cur.rowcount
    except:
      cur.close()
      con.close()
      print "Error when inserting item '%s' to database." % item
      exit(1)
  cur.close()
  con.commit()
  con.close()
  print "%d new items have been inserted." % countOfNewItems

我的代码报告了负数的插入记录(-5141)。

因为我的数据库是空的,所以我可以通过命令行查看插入了多少条记录

select count(*) from items;

4866

你能告诉我有什么问题吗?为什么这两个值不匹配,为什么它是负数?

4

2 回答 2

3

http://docs.python.org/library/sqlite3.html#sqlite3.Cursor.rowcount

尽管 sqlite3 模块的 Cursor 类实现了这个属性,但数据库引擎自己对确定“受影响的行”/“选定的行”的支持是古怪的。

根据 Python DB API 规范的要求,rowcount 属性“如果没有在游标上执行 executeXX() 或最后一个操作的行数无法由接口确定,则为 -1”。

于 2012-01-29T20:59:12.580 回答
2

尝试cur.execute代替con.execute. cur.rowcount然后为我返回 1 进行简单插入。

于 2012-01-29T21:12:23.547 回答