Install
openclaw skills install index-optimizationClawHub Security found sensitive or high-impact capabilities. Review the scan results before using.
针对指定表或集合做查询模式分析、可复用索引设计与 explain 迭代验证。支持两种优化模式:默认全量模式(定位该表/集合所有查询)与单查询模式(用户指定某条查询时,仅分析该查询并查询数据库现有索引);支持两种执行确认模式:需确认模式与免确认模式。
openclaw skills install index-optimization面向单表或单集合执行端到端索引优化:先定位全部相关查询并给出代码位置,再按数据库类型设计可复用索引,最后通过 explain 循环验证,直到达到预期索引命中。
执行前收集以下信息:
全量模式(默认,沿用现有逻辑)单查询模式免确认模式(默认,无需等待用户确认,可直接执行创建/删除索引)需确认模式(执行创建/删除索引前必须等待用户确认)path:line)若数据库类型缺失,明确写出一个假设后继续执行。
按顺序执行,不跳步。
python3 $CODEX_HOME/skills/index-optimization-skill/scripts/collect_table_queries.py --table <table_or_collection_name> --repo-root <repo_root>rg -n --no-heading -S "<name>|query\\.|\\.Table\\(" apps pkg docsrg -n --no-heading -S "<name>|Collection\\(|\\.find\\(|\\.aggregate\\(|\\.explain\\(" apps pkg docspath:line。[path:line](/absolute/path/to/file#Lline)#L<line>。SHOW INDEX / pg_indexes;Mongo getIndexes())。将输入查询按访问模式分组:
>, <, BETWEEN, ORDER BY ... LIMITUPDATE/DELETE 条件status/is_del/type)单查询模式下,仅分析该目标查询,不扩展到其他查询。
使用 references/index-rules.md 的数据库规则。
[path:line](/absolute/path/to/file#Lline))key、type、rows、Extra/执行计划节点)在创建/删除索引前,必须先输出以下内容:
createIndex/dropIndex)。按执行确认模式进入下一步:
需确认模式:只有用户明确确认后,才能进入下一步执行。免确认模式:无需等待用户确认,直接进入下一步执行;但必须在输出中记录“免确认执行”。DROP INDEX/dropIndex。docs/sql/<date>_<table>_index_optimization.sql 中写 DDL。createIndex 与对应 dropIndex 回滚语句。NONE 或等效状态)。如果 explain 未命中预期索引:
若 3 次重设计后仍未命中,停止并报告根因与最稳妥替代方案。
按以下顺序输出:
表与数据库上下文查询输入
访问模式汇总索引方案(DDL + 使用位置)索引变更依据与确认记录
Explain 验证(优化前/后)
NONE)、关键计划信息(如 type/rows/Extra 或执行计划节点)迭代日志最终建议回滚 SQL[path:line](/absolute/path/to/file#Lline)。需确认模式 下,未获确认不得执行索引创建或删除。免确认模式 下,可直接执行索引创建或删除,但必须记录“免确认执行”。DROP INDEX 或 Mongo dropIndex)。references/index-rules.mdscripts/collect_table_queries.py# 1) 查询定位(含 path:line)
python3 $CODEX_HOME/skills/index-optimization-skill/scripts/collect_table_queries.py --table wallet --repo-root .
# 2) 手工补充扫描
rg -n --no-heading -S "wallet|FROM|JOIN|UPDATE|INSERT INTO|DELETE FROM|Collection\\(|\\.find\\(|\\.aggregate\\(" apps pkg docs
# 3) 单查询模式先查已有索引(示例)
mysql -e "SHOW INDEX FROM wallet;"
psql -c "SELECT indexname, indexdef FROM pg_indexes WHERE tablename = 'wallet';"
mongosh --eval "db.wallet.getIndexes()"
# 4) 验证 Skill 结构
python3 $CODEX_HOME/skills/.system/skill-creator/scripts/quick_validate.py $CODEX_HOME/skills/index-optimization-skill