轻量级数据库操作工具,支持 MySQL、PostgreSQL、SQLite 三大主流数据库。
禁止行为:
schema.sql、init.sql 等文件来回答表结构必须行为:
scripts/list-tables.ts 查询实际数据库中的表列表scripts/describe-table.ts 查询实际数据库中的表结构原因:
正确示例:
用户问:"查看 users 表有哪些字段"
❌ 错误:读取 schema.sql 或 User.java 来回答
✅ 正确:运行 describe-table.ts 脚本查询实际数据库
唯一例外:
用户请求
│
▼
检查是否已有连接信息
│
├──▶ 有 ──▶ 直接使用
│
└──▶ 无 ──▶ 智能探索项目(见下方)
│
├──▶ 找到一个 ──▶ 直接使用
│
├──▶ 找到多个 ──▶ 询问用户选择哪个
│
└──▶ 未找到 ──▶ 询问用户提供连接信息
当用户未提供连接信息时,先尝试从项目中自动发现:
使用 glob 和 read 工具,按优先级搜索:
1. 环境变量文件
- .env, .env.local, .env.development, .env.production
2. 应用配置文件(常见框架)
- **Spring Boot**: application.yml, application.yaml, application.properties
(注意:可能在 backend/, server/, api/ 等子目录)
- **Node.js**: config/database.yml, config/database.yaml, knexfile.*, drizzle.config.*
- **Django**: settings.py
- **Rails**: config/database.yml, config/database.yaml
- **Laravel**: .env, config/database.php
3. ORM 配置
- **Prisma**: prisma/schema.prisma
- **Drizzle**: drizzle.config.ts, drizzle.config.js
# 查找环境变量文件
glob pattern=".env*"
# 查找 Spring Boot 配置(支持 monorepo)
glob pattern="**/application*.yml"
glob pattern="**/application*.yaml"
glob pattern="**/application*.properties"
# 查找 Node.js 配置
glob pattern="**/database.{yml,yaml,json,js,ts}"
glob pattern="**/knexfile.{js,ts}"
# 查找 Prisma/Drizzle
glob pattern="**/schema.prisma"
glob pattern="**/drizzle.config.{js,ts}"
找到配置文件后,读取并提取连接信息:
关键变量名:
DATABASE_URL, DB_URL, MYSQL_URL, POSTGRES_URL, spring.datasource.urlDB_HOST, DB_PORT, DB_USER, DB_PASSWORD, DB_NAME, DB_DATABASE示例解析:
# Spring Boot application.yml
spring:
datasource:
url: jdbc:mysql://localhost:3306/mydb
username: root
password: secret
# .env
DATABASE_URL=mysql://root:secret@localhost:3306/mydb
// drizzle.config.ts
export default {
connection: 'mysql://root:secret@localhost:3306/mydb'
}
配置文件可能包含占位符,需要解析:
# 带默认值的占位符
url: jdbc:mysql://${DB_HOST:localhost}:${DB_PORT:3306}/${DB_NAME:mydb}
解析规则:
${VAR_NAME:default} 格式,优先读取环境变量如果发现多个数据库连接配置,使用 ask-user-question 询问用户:
发现以下数据库连接:
1. MySQL - localhost:3306/mydb (来自 application.yml)
2. PostgreSQL - localhost:5432/app ( 来自 .env)
请问要使用哪个?
收集到的连接信息统一转换为以下格式:
数据库类型: mysql / postgresql / sqlite
主机: localhost
端口: 3306
用户名: root
密码: secret
数据库名: mydb
# 或 URL 形式
mysql://root:secret@localhost:3306/mydb
技能脚本依赖 TypeScript 运行时和数据库驱动,需要全局安装:
npm install -g tsx mysql2 pg better-sqlite3
> 注意:better-sqlite3 需要编译本地模块,确保系统有 make 和 gcc 工具。
> 为什么需要 NODE_PATH?
>
> Node.js 有两种模块系统:
> - CommonJS (require): 支持 NODE_PATH,可以找到全局安装的包
> - ESM (import): 不支持 NODE_PATH,这是 Node.js 的设计决策
>
> 本技能的脚本使用 require(而非 import)来加载全局依赖,因此需要设置 NODE_PATH。
第一步:设置 NODE_PATH 环境变量
export NODE_PATH=$(npm root -g)
第二步:获取技能目录路径
所有脚本使用相对于技能根目录的路径。获取技能目录:
# 方法 1:通过 SKILL.md 位置推断(推荐)
SKILL_DIR=$(dirname $(grep -rl "name: db-toolkit" ~/.config/opencode/skills 2>/dev/null | head -1))
# 方法 2:直接使用本文件所在目录
# SKILL_DIR=/path/to/db-toolkit
第三步:运行脚本
使用 $SKILL_DIR/scripts/ 前缀执行脚本:
tsx $SKILL_DIR/scripts/test-connection.ts --url "mysql://..."
tsx $SKILL_DIR/scripts/test-connection.ts --url "mysql://root:secret@localhost:3306/mydb"
# 或分开参数
tsx $SKILL_DIR/scripts/test-connection.ts \
--db-type mysql \
--host localhost \
--port 3306 \
--user root \
--password secret \
--database mydb
tsx $SKILL_DIR/scripts/list-tables.ts --url "mysql://root:secret@localhost:3306/mydb"
tsx $SKILL_DIR/scripts/describe-table.ts --url "mysql://root:secret@localhost:3306/mydb" --table users
对于 DDL 和 DML 操作,根据数据库类型读取对应的参考文档:
| 数据库 | 连接配置 | DDL 模板 | DML 模板 |
|---|---|---|---|
| -------- | ---------- | ---------- | ---------- |
| MySQL | mysql/connection.md | mysql/ddl.md | mysql/dml.md |
| PostgreSQL | postgresql/connection.md | postgresql/ddl.md | postgresql/dml.md |
| SQLite | sqlite/connection.md | sqlite/ddl.md | sqlite/dml.md |
| 脚本 | 功能 | 参数 |
|---|---|---|
| ------ | ------ | ------ |
test-connection.ts | 测试数据库连接 | --url 或 --db-type, --host, --port, --user, --password, --database |
list-tables.ts | 列出所有表 | 连接参数 |
describe-table.ts | 查看表结构 | 连接参数 + --table |
按数据库类型组织,每个数据库包含:
connection.md - 连接配置详解ddl.md - DDL 操作模板(CREATE/ALTER/DROP)dml.md - DML 操作模板(SELECT/INSERT/UPDATE/DELETE)共 1 个版本