GI Database Query Patterns
/install gi-database-query-patterns
Database Query Patterns 数据库查询规范
使用 tkms 的 AsyncSqlSessionTemplate 进行数据库操作。适用于 app/dao 层,MySQL 8.0,UTF8 字符集。
何时使用
- 用户请求「写 dao」「写数据库操作」「查表」
- 实现 app/dao 下的数据访问逻辑
- 设计表结构、索引、SQL 语句
核心 API
from tkms.database.async_template import AsyncSqlSessionTemplate
# 插入
await session.insert(table="t_user", params=entity, primary_key="tid")
# 更新
await session.update(table="t_user", params=entity, primary_key="tid")
# 查询单条
row = await session.query_one("SELECT * FROM t_user WHERE id = :id", {"id": user_id})
# 查询列表
rows = await session.query_list("SELECT * FROM t_user WHERE status = :status", {"status": 1})
操作规范
1. 插入
async def add_user(self, user: UserEntity):
await self.session.insert(table="t_user", params=user, primary_key="tid")
params:实体或字典,字段名与表列对应primary_key:主键字段名,用于自增主键
2. 更新
async def update_user(self, user: UserEntity):
await self.session.update(table="t_user", params=user, primary_key="tid")
- 按主键更新,需包含主键值
3. 查询单条
async def get_by_id(self, user_id: int) -> UserEntity | None:
row = await session.query_one(
"SELECT * FROM t_user WHERE id = :id",
{"id": user_id}
)
return UserEntity(**row) if row else None
4. 查询列表(含分页)
async def get_list(self, status: int, page: int, page_size: int):
offset = (page - 1) * page_size
rows = await session.query_list(
"SELECT * FROM t_user WHERE status = :status ORDER BY id DESC LIMIT :limit OFFSET :offset",
{"status": status, "limit": page_size, "offset": offset}
)
return [UserEntity(**r) for r in rows]
5. 统计
async def count_by_status(self, status: int) -> int:
row = await session.query_one(
"SELECT COUNT(*) as cnt FROM t_user WHERE status = :status",
{"status": status}
)
return row["cnt"] if row else 0
SQL 规范
- 参数化:一律用
:param占位,禁止字符串拼接 - 表名:项目约定表前缀(如
t_) - 索引:WHERE、ORDER BY 常用列建索引
- 避免 N+1:批量查询用 IN 或 JOIN,避免循环单条查
建表规范
- 主键必建
- 按查询需求建索引(单列、复合)
- 字符集 UTF8
- 时间字段:
create_time、update_time,类型 DATETIME
CREATE TABLE t_user (
tid BIGINT PRIMARY KEY AUTO_INCREMENT,
id VARCHAR(64) NOT NULL UNIQUE,
name VARCHAR(128),
status TINYINT DEFAULT 1,
create_time DATETIME DEFAULT CURRENT_TIMESTAMP,
update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
INDEX idx_status (status),
INDEX idx_create_time (create_time)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
事务
若框架支持事务,批量操作应包裹在事务内,保证原子性。
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install gi-database-query-patterns - After installation, invoke the skill by name or use
/gi-database-query-patterns - Provide required inputs per the skill's parameter spec and get structured output
What is GI Database Query Patterns?
Write database queries using tkms AsyncSqlSessionTemplate. Use when implementing dao layer, writing SQL, or when the user asks for database operations with i... It is an AI Agent Skill for Claude Code / OpenClaw, with 502 downloads so far.
How do I install GI Database Query Patterns?
Run "/install gi-database-query-patterns" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is GI Database Query Patterns free?
Yes, GI Database Query Patterns is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does GI Database Query Patterns support?
GI Database Query Patterns is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created GI Database Query Patterns?
It is built and maintained by laimiaohua (@laimiaohua); the current version is v1.0.0.