3

我在 Windows XP 上使用带有内置 sqlite3 模块的 python 2.7。代码如下所示:

#!/usr/bin/env python2

import sqlite3
import sys

def open_db(nam):
    conn = sqlite3.connect(sys.argv[1])
    # Let rows returned be of dict/tuple type
    conn.row_factory = sqlite3.Row
    print "Openned database %s as %r" % (nam, conn)
    return conn

def copy_table(table, src, dest):
    print "Copying %s %s => %s" % (table, src, dest)
    sc = src.execute('SELECT * FROM %s' % table)
    ins = None
    dc = dest.cursor()
    for row in sc.fetchall():
        if not ins:
            cols = tuple([k for k in row.keys() if k != 'id'])
            ins = 'INSERT OR REPLACE INTO %s %s VALUES (%s)' % (table, cols,
                                                     ','.join(['?'] * len(cols)))
            print 'INSERT stmt = ' + ins
        c = [row[c] for c in cols]
        dc.execute(ins, c)

    dest.commit()

src_conn  = open_db(sys.argv[1])
dest_conn = open_db(sys.argv[2])

copy_table('audit', src_conn, dest_conn)

当我用db_copy.py src.db dest.db源数据库运行它时,它翻了一番。所以我将源文件属性设置为只读。我现在得到:

sqlite3.OperationalError: attempt to write a readonly database

似乎源数据库连接和目标数据库连接混合在一起?我已经调试了几个小时没有找到原因。

4

1 回答 1

3

您忽略了nam参数并sys.argv[1]用于所有调用open_db()

def open_db(nam):
    conn = sqlite3.connect(sys.argv[1])

这将打开第一个命名数据库两次,分别为src_conndest_conn。改用nam

def open_db(nam):
    conn = sqlite3.connect(nam)
于 2013-05-12T12:22:25.400 回答