parse-table
SKILL.md
Step 1: Parse Table Definition
从用户输入的表定义中提取关键信息。
Input Format
Table: products
Fields:
- id (primary key)
- name (string, 100, required)
- category_id (foreign key -> categories)
- description (text, nullable)
- price (decimal 10,2, required)
- stock (integer, default 0)
- status (tinyint, default 1)
输入容错与默认推断
- 允许使用以下别名:
Table/表名/表,Module/模块,Model/模型,Fields/字段。 - 允许省略
Fields:标题,仅用-列表表示字段。 - 若只提供
table,则按命名规则推断{Module}与{Model}。 - 若用户显式提供
Module/Model,优先使用用户输入(覆盖推断)。 - 缺少
table时必须先向用户确认,不进行推断生成。
字段解析补充
required表示nullable = false,nullable表示可空;两者都未出现时默认不可空。- 支持别名:
int/integer、bool/boolean、pk/primary key、fk/foreign key。 foreign key -> xxx解析为foreignKey类型,默认index()。
冲突处理优先级
- 用户显式指定(Module/Model/table/字段规则)
- 规则推断(命名规则与默认字段规则)
- 兜底:要求用户澄清后再继续
Output Variables
| Variable | Rule | Example |
|---|---|---|
{table} |
snake_case plural | products |
{Model} |
PascalCase singular | Product |
{Module} |
PascalCase | Product |
{module} |
snake_case | product |
{resources} |
kebab-case plural | products |
{resource} |
kebab-case singular | product |
Field Type Parsing
| Input | Type | Length | Required | Default | FK Target |
|---|---|---|---|---|---|
string, 100 |
string | 100 | no | null | - |
string, 100, required |
string | 100 | yes | null | - |
integer, default 0 |
integer | - | no | 0 | - |
foreign key -> categories |
foreignKey | - | no | 0 | categories |
decimal 10,2 |
decimal | 10,2 | no | null | - |
tinyint, default 1 |
tinyint | - | no | 1 | - |
text, nullable |
text | - | no | null | - |
Naming Conventions
- Module: 通常与 Model 同名,除非用户明确指定
- Table: 复数形式 (products, order_items)
- Model: 单数形式 (Product, OrderItem)
- Route: kebab-case (products, order-items)