Skip to content

Links

Get linked records

获取被链接的行的信息。可以一次查询多个行的被链接行的信息。

base.get_linked_records(table_id, link_column_key, rows)

其中

  • table_id: 子表的 id
  • link_column_key: 链接列的 key (非 link_id )
  • rows: 需要查找链接信息的行的列表,每一列表项包含三个参数 row_id, offset (查找的偏移量, 默认为0), limit (查找的数量, 默认为10)
例子
base.get_linked_records('0000', '89o4', rows=[
        {'row_id': 'FzNqJxVUT8KrRjewBkPp8Q', 'limit': 2, 'offset': 0},
        {'row_id': 'Jmnrkn6TQdyRg1KmOM4zZg', 'limit': 20}
    ])

# 返回的数据结构, 包含被链接的行的 ID 和显示值。每个行所连接的行,按照被链接的行的创建时间顺序以数组形式返回。
{
    'FzNqJxVUT8KrRjewBkPp8Q': [
        {'row_id': 'LocPgVvsRm6bmnzjFDP9bA', 'display_value': '1'},                            
        {'row_id': 'OA6x7CYoRuyc2pT52Znfmw', 'display_value': '3'},
    ...
    ],
    'Jmnrkn6TQdyRg1KmOM4zZg': [
        {'row_id': 'LocPgVvsRm6bmnzjFDP9bA', 'display_value': '1'},     
        {'row_id': 'OA6x7CYoRuyc2pT52Znfmw', 'display_value': '3'},
         ...
    ]
}

添加链接,链接其他表记录

base.add_link(link_id, table_name, other_table_name, row_id, other_row_id)

其中

  • link_id: 链接列 data 属性下的 link_id (你可以获取 base 的 metadata,找到对应的列,然后找一下 data 字段下的 link_id 字段, 或者通过下方的 get_column_link_id 函数获取。)
  • table_name: 链接表的名字或 id
  • other_table_name: 被链接表的名字或 id
  • row_id: 链接行 id
  • other_row_id: 被链接行的 id
例子
base.add_link('5WeC', 'real-img-files', 'contact', 'CGtoJB1oQM60RiKT-c5J-g', 'PALm2wPKTCy-jdJNv_UWaQ')

更新链接信息

update_link(self, link_id, table_name, other_table_name, row_id, other_rows_ids)

其中

  • link_id: 链接列 data 属性下的 link_id
  • table_name: 链接表的名字或 id
  • other_table_name: 被链接表的名字或 id
  • row_id: 链接行 id
  • other_rows_ids: 被链接行的 id 列表
例子
base.update_link(
        link_id='r4IJ',
        table_name='Table1',
        other_table_name='Table2',
        row_id='BXhEm9ucTNu3FjupIk7Xug',
        other_rows_ids=[
          'exkb56fAT66j8R0w6wD9Qg',
          'DjHjwmlRRB6WgU9uPnrWeA'
        ]
    )

批量更新链接信息

base.batch_update_links(link_id, table_name, other_table_name, row_id_list, other_rows_ids_map)

其中

  • table_name: 链接表的名字或 id
  • other_table_name: 被链接表的名字或 id
例子
link_id = "WaW5"
table_name ="Table1"
other_table_name = "Table2"
row_id_list = ["fRLglslWQYSGmkU7o6KyHw","eSQe9OpPQxih8A9zPXdMVA","FseN8ygVTzq1CHDqI4NjjQ"]
other_rows_ids_map = {
        "FseN8ygVTzq1CHDqI4NjjQ":["OcCE8aX8T7a4dvJr-qNh3g","JckTyhN0TeS8yvH8D3EN7g"],
        "eSQe9OpPQxih8A9zPXdMVA":["cWHbzQiTR8uHHzH_gVSKIg","X56gE7BrRF-i61YlE4oTcw"],
        "fRLglslWQYSGmkU7o6KyHw":["MdfUQiWcTL--uMlrGtqqgw","E7Sh3FboSPmfBlDsrj_Fhg","UcZ7w9wDT-uVq4Ohtwgy9w"]
}

base.batch_update_links(link_id, table_name, other_table_name, row_id_list, other_rows_ids_map)

移除某个链接

base.remove_link(link_id, table_name, other_table_name, row_id, other_row_id)

其中

  • table_name: 链接表的名字或 id
  • other_table_name: 被链接表的名字或 id
例子
base.remove_link('5WeC', 'real-img-files', 'contact', 'CGtoJB1oQM60RiKT-c5J-g', 'PALm2wPKTCy-jdJNv_UWaQ')

通过列名来获取链接的id

base.get_column_link_id(table_name, column_name)

其中

  • table_name: 子表名称或 id
例子
base.get_column_link_id('Table1', '记录') # 返回链接的id,如‘aHL2’