如何在RethinkDB中附加表?

时间:2016-04-21 15:37:28

标签: rethinkdb rethinkdb-python database nosql

我在RethinkDB上有3个表t1,t2和t3

t1中的每个文档(d)有7个键(k)和相关值。 t1看起来像:

{"key1": ["valued1k1t1"], "key2": ["valued1k2t1"], "key3": ["valued1k3t1"] , "key4": ["valued1k4t1"] ,"id": "UUIDd1t1", "key5": ["valued1k5t1"], "key6": ["valued1k6t1], "key7": "valued1k7t1"}
{"key1": ["valued2k1t1"], "key2": ["valued2k2t1"], "key3": ["valued2k3t1"] , "key4": ["valued2k4t1"] ,"id": "UUIDd2t1", "key5": ["valued2k5t1"], "key6": ["valued2k6t1], "key7": "valued2k7t1"}
...

t2具有相同的结构:

{"key1": ["valued1k1t2"], "key2": ["valued1k2t2"], "key3": ["valued1k3t2"] , "key4": ["valued1k4t2"] ,"id": "UUIDd1t2", "key5": ["valued1k5t2"], "key6": ["valued1k6t2], "key7": "valued1k7t2"}
...

和t3也是:

{"key1": ["valued1k1t3"], "key2": ["valued1k2t3"], "key3": ["valued1k3t3"] , "key4": ["valued1k4t3"] ,"id": "UUIDd3t3", "key5": ["valued1k5t3"], "key6": ["valued1k6t3], "key7": "valued1k7t3"}
...

我想创建一个看起来像这样的表格t4:

{"key1": ["valued1k1t1"], "key2": ["valued1k2t1"], "key3": ["valued1k3t1"] , "key4": ["valued1k4t1"] ,"id": "UUIDd1t1", "key5": ["valued1k5t1"], "key6": ["valued1k6t1], "key7": "valued1k7t1"}
{"key1": ["valued2k1t1"], "key2": ["valued2k2t1"], "key3": ["valued2k3t1"] , "key4": ["valued2k4t1"] ,"id": "UUIDd2t1", "key5": ["valued2k5t1"], "key6": ["valued2k6t1], "key7": "valued2k7t1"}
...
{"key1": ["valued1k1t2"], "key2": ["valued1k2t2"], "key3": ["valued1k3t2"] , "key4": ["valued1k4t2"] ,"id": "UUIDd1t2", "key5": ["valued1k5t2"], "key6": ["valued1k6t2], "key7": "valued1k7t2"}
...
{"key1": ["valued1k1t3"], "key2": ["valued1k2t3"], "key3": ["valued1k3t3"] , "key4": ["valued1k4t3"] ,"id": "UUIDd1t3", "key5": ["valued1k5t3"], "key6": ["valued1k6t3], "key7": "valued1k7t3"}
...

我使用Python客户端驱动程序,哪个查询可以完成这项工作?

1 个答案:

答案 0 :(得分:1)

好的,我找到了解决方案。假设您的表位于名为DB的数据库中。在DB中创建一个表t4然后执行:

>> r.db("DB").table("t4").insert(r.db("DB").table("t1")).run()
>> r.db("DB").table("t4").insert(r.db("DB").table("t2")).run()
>> r.db("DB").table("t4").insert(r.db("DB").table("t3")).run()