Install
openclaw skills install db-toolkit轻量级多数据库操作工具,支持 MySQL/PostgreSQL/SQLite 的 DDL/DML 操作和 Schema 探索。 触发场景: - 用户说"连接数据库"、"测试数据库连接"、"连接MySQL/PostgreSQL/SQLite" - 用户说"查看表结构"、"列出所有表"、"查看 users 表有哪些字段" - 用户说"执行SQL"、"查询数据"、"插入数据"、"更新数据"、"删除数据" - 用户说"创建表"、"修改表结构"、"删除表"、"添加字段" - 任何涉及数据库 DDL/DML 操作的请求
openclaw skills install db-toolkit轻量级数据库操作工具,支持 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)