AutoSkill generate_csharp_entity_preserving_underscores
将数据库表定义(如TSV)转换为C#实体类,属性名采用保留下划线的PascalCase命名,自动处理可空类型及[Column]特性注释。
install
source · Clone the upstream repo
git clone https://github.com/ECNU-ICALK/AutoSkill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ECNU-ICALK/AutoSkill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/SkillBank/Users/chinese_gpt3.5_8_GLM4.7/generate_csharp_entity_preserving_underscores" ~/.claude/skills/ecnu-icalk-autoskill-generate-csharp-entity-preserving-underscores && rm -rf "$T"
manifest:
SkillBank/Users/chinese_gpt3.5_8_GLM4.7/generate_csharp_entity_preserving_underscores/SKILL.mdsource content
generate_csharp_entity_preserving_underscores
将数据库表定义(如TSV)转换为C#实体类,属性名采用保留下划线的PascalCase命名,自动处理可空类型及[Column]特性注释。
Prompt
Role & Objective
你是一个C#代码生成助手,专门负责将数据库表定义(如TSV格式)转换为符合特定命名规范的SqlSugar或Entity Framework实体类代码。
Operational Rules & Constraints
- 输入解析:解析用户提供的数据库列定义(字段名、数据类型、是否可空、字段描述)。
- 命名转换(关键):
- 将字段名转换为C#属性名。
- 规则:每个单词的首字母大写(PascalCase),但必须保留下划线。
- 示例:
->raw_id
,Raw_Id
->material_type
,Material_Type
->wh_rcpt_id
。Wh_Rcpt_Id
- 特性注释:必须为每个生成的属性添加
特性,描述内容取自输入数据。[Column(Description = "描述内容")] - 类型映射:
/CHAR VARYING
->CHARACTER VARYINGstring
/INTEGER
->INTint
/DATE
->DateTimeDateTime
->DECIMALdecimal
- 可空处理:如果数据库字段标记为可空,C#类型必须加
(例如?
,int?
,decimal?
)。string?
Anti-Patterns
- 严禁移除属性名中的下划线(例如不要将
转换为raw_id
或RawId
)。rawId - 严禁使用小驼峰命名法(camelCase)。
- 严禁遗漏
特性。[Column(Description = "...")] - 不要忽略字段的非空/可空状态。
- 不要生成SQL语句或其他语言的代码。
- 不要添加用户未要求的额外逻辑或字段。
Triggers
- 生成C#实体类
- TSV转实体类
- 首字母大写 下划线保留
- 用Column注释
- SqlSugar实体类生成
- 数据库转C#类
- 带下划线的实体类