Read-only MySQL query skill. Query multiple databases safely with write protection.
- Copy the example config:
cp connections.example.json connections.json- Add your database credentials:
{
"databases": [
{
"name": "prod",
"description": "Production - users, orders, transactions",
"host": "db.example.com",
"port": 3306,
"database": "app_prod",
"user": "readonly",
"password": "secret",
"ssl_disabled": false
}
]
}- Secure the config:
chmod 600 connections.json# List configured databases
python3 scripts/query.py --list
# List tables
python3 scripts/query.py --db prod --tables
# Show schema
python3 scripts/query.py --db prod --schema
# Run query
python3 scripts/query.py --db prod --query "SELECT * FROM users" --limit 100| Field | Required | Default | Description |
|---|---|---|---|
| name | Yes | - | Database identifier |
| description | Yes | - | What data it contains (for auto-selection) |
| host | Yes | - | Hostname |
| port | No | 3306 | Port |
| database | Yes | - | Database name |
| user | Yes | - | Username |
| password | Yes | - | Password |
| ssl_disabled | No | false | Disable SSL connections |
| ssl_ca | No | - | Path to CA certificate |
| ssl_cert | No | - | Path to client certificate |
| ssl_key | No | - | Path to client private key |
- Read-only sessions: MySQL
SET SESSION TRANSACTION READ ONLYblocks writes at session level - Query validation: Only SELECT, SHOW, DESCRIBE, EXPLAIN, WITH allowed
- Single statement: No multi-statement queries (prevents
SELECT 1; DROP TABLE) - Timeouts: 30s query timeout (max_execution_time), 10s connection timeout
- Memory cap: Max 10,000 rows per query
- Credential protection: Passwords sanitized from error messages
pip install mysql-connector-python