PicoBot/.qoder/skills/lark-base/references/lark-base-record-upsert.md
ooodc a7883dbed9 refactor(todo): 重构待办事项管理逻辑及更新状态规则
- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段
- 强制每个任务都必须有唯一 id,且由用户负责生成
- 修改合并模式逻辑,merge=true 下保留未提及的旧任务
- 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress)
- 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled
- 优化状态转换校验,允许特定状态间合法切换
- 简化任务变更消息,移除详细的新增/更新/移除统计
- 更新文档和示例,明确 id 必须由用户生成和使用
- 修复和补充测试,增强状态转换和合并模式验证
- 调整任务时间戳生成逻辑,统一使用当前时间及索引
- 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
2026-06-13 09:22:33 +08:00

2.3 KiB
Raw Blame History

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 是字段名或字段 IDvalue 是该字段的 CellValue
  • 一次请求里同一字段只用一种标识,避免重复写入冲突。
  • 写入前先 +field-list 确认字段类型和字段名/ID。
  • CellValue 统一看 lark-base-cell-value.md
{
  "项目名称": "Apollo",
  "状态": "进行中",
  "完成时间": "2026-03-24 10:00:00"
}

返回重点

  • 创建时返回 recordcreated: true
  • 更新时返回 recordupdated: true
  • 如果写入了 formula / lookup / created_at / updated_at / created_by / updated_by 等只读字段,返回里可能出现 ignored_fields,这些字段不会被更新。

坑点

  • --record-id 就一定更新;不传就一定创建,不会自动查重或按业务键 upsert。
  • select 写入未知选项时平台可能自动新增选项;如果不是要新增选项,先用 +field-list / +field-search-options 确认真实选项名。
  • 这是写入操作,执行前必须确认目标表和字段。

参考