- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段 - 强制每个任务都必须有唯一 id,且由用户负责生成 - 修改合并模式逻辑,merge=true 下保留未提及的旧任务 - 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress) - 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled - 优化状态转换校验,允许特定状态间合法切换 - 简化任务变更消息,移除详细的新增/更新/移除统计 - 更新文档和示例,明确 id 必须由用户生成和使用 - 修复和补充测试,增强状态转换和合并模式验证 - 调整任务时间戳生成逻辑,统一使用当前时间及索引 - 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
2.3 KiB
2.3 KiB
base +record-upsert
前置条件: 先阅读
../lark-shared/SKILL.md了解认证、全局参数和安全规则。
创建记录,或在带 --record-id 时更新记录。
推荐命令
# 创建记录
lark-cli base +record-upsert --base-token <base_token> --table-id <table_id> \
--json '{"项目名称":"Apollo","状态":"进行中"}'
# 更新记录
lark-cli base +record-upsert --base-token <base_token> --table-id <table_id> --record-id <record_id> \
--json '{"项目名称":"Apollo","状态":"完成","完成时间":"2026-03-24 10:00:00"}'
参数
| 参数 | 必填 | 说明 |
|---|---|---|
--base-token <token> |
是 | Base Token |
--table-id <id_or_name> |
是 | 表 ID 或表名 |
--record-id <id> |
否 | 传入时走更新,不传时走创建 |
--json <body> |
是 | 字段写入对象,类型 Map<FieldNameOrID, CellValue> |
API
- 创建:
POST /open-apis/base/v3/bases/:base_token/tables/:table_id/records - 更新:带
--record-id时改走PATCH /records/:record_id
--json 结构
--json必须是 JSON object map,形状是Map<FieldNameOrID, CellValue>。- key 是字段名或字段 ID;value 是该字段的
CellValue。 - 一次请求里同一字段只用一种标识,避免重复写入冲突。
- 写入前先
+field-list确认字段类型和字段名/ID。 - CellValue 统一看 lark-base-cell-value.md。
{
"项目名称": "Apollo",
"状态": "进行中",
"完成时间": "2026-03-24 10:00:00"
}
返回重点
- 创建时返回
record和created: true。 - 更新时返回
record和updated: true。 - 如果写入了
formula / lookup / created_at / updated_at / created_by / updated_by等只读字段,返回里可能出现ignored_fields,这些字段不会被更新。
坑点
- 有
--record-id就一定更新;不传就一定创建,不会自动查重或按业务键 upsert。 - select 写入未知选项时平台可能自动新增选项;如果不是要新增选项,先用
+field-list/+field-search-options确认真实选项名。 - 这是写入操作,执行前必须确认目标表和字段。
参考
- lark-base-cell-value.md — CellValue 格式规范