导入 RethinkDB 时出错
Error importing to RethinkDB
我在尝试将 json 文件导入 Google 云计算实例上的 RethinkDB 时遇到错误,我不知道如何处理此错误。任何帮助表示赞赏。这是错误:
root@my-server-name:~# rethinkdb import -f users_0.json --table test.users
Traceback (most recent call last):
File "/usr/local/bin/rethinkdb-import", line 9, in <module>
load_entry_point('rethinkdb==2.3.0.post1', 'console_scripts', 'rethinkdb-import')()
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_import.py", line 929, in main
import_file(options)
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_import.py", line 904, in import_file
pkey = rdb_call_wrapper(conn_fn, "table check", table_check, db, table, options["create_args"], options["force"])
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_backup.py", line 78, in rdb_call_wrapper
return fn(progress, conn, *args, **kwargs)
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_import.py", line 885, in table_check
if not options["quiet"]:
NameError: global name 'options' is not defined
RethinkDB 运行 在与 Docker 相同的虚拟机上。我用这个命令实例化了它:
docker run -i -t -p 8080:8080 -p 28015:28015 -p 29015:29015 rethinkdb
他们正在使用他们尚未定义的变量。我从 pypi 中提取了那个版本 2.3.0.post1 的代码(包括带有下面错误的函数)。我还检查了版本 2.2.0.post2,我在那里没有看到那个错误,所以降级那个包,你应该没问题。
def table_check(progress, conn, db, table, create_args, force):
pkey = None
if db == "rethinkdb":
raise RuntimeError("Error: Cannot import a table into the system database: 'rethinkdb'")
if db not in r.db_list().run(conn):
r.db_create(db).run(conn)
if table in r.db(db).table_list().run(conn):
if not force:
raise RuntimeError("Error: Table already exists, run with --force if you want to import into the existing table")
if 'primary_key' in create_args:
pkey = r.db(db).table(table).info()["primary_key"].run(conn)
if create_args["primary_key"] != pkey:
raise RuntimeError("Error: Table already exists with a different primary key")
else:
if 'primary_key' in create_args:
pkey = create_args["primary_key"]
else:
if not options["quiet"]:
print("no primary key specified, using default primary key when creating table")
r.db(db).table_create(table, **create_args).run(conn)
return pkey
我在尝试将 json 文件导入 Google 云计算实例上的 RethinkDB 时遇到错误,我不知道如何处理此错误。任何帮助表示赞赏。这是错误:
root@my-server-name:~# rethinkdb import -f users_0.json --table test.users
Traceback (most recent call last):
File "/usr/local/bin/rethinkdb-import", line 9, in <module>
load_entry_point('rethinkdb==2.3.0.post1', 'console_scripts', 'rethinkdb-import')()
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_import.py", line 929, in main
import_file(options)
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_import.py", line 904, in import_file
pkey = rdb_call_wrapper(conn_fn, "table check", table_check, db, table, options["create_args"], options["force"])
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_backup.py", line 78, in rdb_call_wrapper
return fn(progress, conn, *args, **kwargs)
File "/usr/local/lib/python2.7/dist-packages/rethinkdb/_import.py", line 885, in table_check
if not options["quiet"]:
NameError: global name 'options' is not defined
RethinkDB 运行 在与 Docker 相同的虚拟机上。我用这个命令实例化了它:
docker run -i -t -p 8080:8080 -p 28015:28015 -p 29015:29015 rethinkdb
他们正在使用他们尚未定义的变量。我从 pypi 中提取了那个版本 2.3.0.post1 的代码(包括带有下面错误的函数)。我还检查了版本 2.2.0.post2,我在那里没有看到那个错误,所以降级那个包,你应该没问题。
def table_check(progress, conn, db, table, create_args, force):
pkey = None
if db == "rethinkdb":
raise RuntimeError("Error: Cannot import a table into the system database: 'rethinkdb'")
if db not in r.db_list().run(conn):
r.db_create(db).run(conn)
if table in r.db(db).table_list().run(conn):
if not force:
raise RuntimeError("Error: Table already exists, run with --force if you want to import into the existing table")
if 'primary_key' in create_args:
pkey = r.db(db).table(table).info()["primary_key"].run(conn)
if create_args["primary_key"] != pkey:
raise RuntimeError("Error: Table already exists with a different primary key")
else:
if 'primary_key' in create_args:
pkey = create_args["primary_key"]
else:
if not options["quiet"]:
print("no primary key specified, using default primary key when creating table")
r.db(db).table_create(table, **create_args).run(conn)
return pkey