-
-
Notifications
You must be signed in to change notification settings - Fork 2
seed
GitHub Actions edited this page Feb 13, 2026
·
1 revision
Category: Database Commands
Load seed data into the database with ordered, idempotent execution.
Apply seed data to populate database tables for development, testing, or initial production data.
Features:
- ✅ Ordered execution (01_, 02_, 03_ prefixes)
- ✅ Idempotent with ON CONFLICT
- ✅ Hot loading (no restart needed)
- ✅ Selective execution
- ✅ Multiple seed directories supported
nself db seed [options] [seed_name]| Argument | Description |
|---|---|
seed_name |
Optional: Specific seed to run |
| (none) | Run all seeds in order |
| Option | Description |
|---|---|
--list |
List available seed files |
-v, --verbose |
Show detailed output |
--force |
Skip confirmation prompts |
- Location:
hasura/seeds/default/ - Format:
*.sqlfiles
- Location:
db/seeds/ - Format:
*.sqlor0N_name.sqlfor ordering
nself db seedOutput:
→ Loading seed data...
⠋ Running: 01_users.sql
✓ Inserted 5 rows
⠋ Running: 02_roles.sql
✓ Inserted 3 rows
✓ All seeds applied successfully
nself db seed users
# Or
nself db seed 01_usersnself db seed --listOutput:
Available seed files:
01_users.sql
02_roles.sql
03_demo_data.sql
-- Seed: Demo Users
-- Description: Create demo accounts for development
-- Idempotent: Uses ON CONFLICT to allow re-running
INSERT INTO auth.users (id, email, display_name, role)
VALUES
('demo-user-1', 'demo@example.com', 'Demo User', 'user'),
('demo-user-2', 'admin@example.com', 'Admin User', 'admin'),
('demo-user-3', 'test@example.com', 'Test User', 'user')
ON CONFLICT (email) DO NOTHING;
INSERT INTO user_preferences (user_id, theme, notifications)
VALUES
('demo-user-1', 'dark', true),
('demo-user-2', 'light', false)
ON CONFLICT (user_id) DO UPDATE
SET theme = EXCLUDED.theme,
notifications = EXCLUDED.notifications;Use ON CONFLICT:
-- For unique constraints
INSERT INTO roles (id, name)
VALUES (1, 'admin'), (2, 'user')
ON CONFLICT (id) DO NOTHING;
-- Update if exists
INSERT INTO settings (key, value)
VALUES ('app_name', 'MyApp')
ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value;Use IF NOT EXISTS:
-- For schema objects
CREATE TYPE IF NOT EXISTS user_status AS ENUM ('active', 'inactive');Check before inserting:
-- Delete and re-insert for exact state
DELETE FROM demo_data WHERE demo = true;
INSERT INTO demo_data (...) VALUES (...);db/seeds/
├── 01_users.sql
├── 02_roles.sql
├── 03_user_roles.sql
└── 04_demo_data.sql
Execution order: 01 → 02 → 03 → 04
-
0N_prefix for ordering - Descriptive names
-
.sqlextension
Examples:
01_core_tables.sql02_reference_data.sql03_test_users.sql04_demo_content.sql
# Reset database and seed
nself db reset
nself db migrate up
nself db seedSeeds:
01_admin_user.sql # Create admin account
02_demo_users.sql # Test users
03_sample_content.sql # Example data
# Load test fixtures
nself db seed test_fixturesSeed:
-- test_fixtures.sql
INSERT INTO users (id, email, password_hash)
VALUES
('test-user-1', 'test1@example.com', '$2a$10$...'),
('test-user-2', 'test2@example.com', '$2a$10$...')
ON CONFLICT (email) DO NOTHING;# One-time production seed
nself db seed initial_configSeed:
-- initial_config.sql
INSERT INTO app_settings (key, value)
VALUES
('maintenance_mode', 'false'),
('registration_enabled', 'true'),
('api_rate_limit', '1000')
ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value;-- Good
INSERT INTO roles (name) VALUES ('admin')
ON CONFLICT (name) DO NOTHING;
-- Bad (fails on re-run)
INSERT INTO roles (name) VALUES ('admin');# Good - one concern per file
01_users.sql
02_roles.sql
03_permissions.sql
# Avoid - mixed concerns
01_everything.sql# Good
01_create_admin_user.sql
02_default_organization.sql
# Avoid
seed1.sql
data.sql-- Seed: User Roles
-- Depends on: 01_users.sql, 02_roles.sql
-- Creates join table entries for user-role relationships-- Only seed if table is empty
INSERT INTO config (key, value)
SELECT 'app_name', 'MyApp'
WHERE NOT EXISTS (SELECT 1 FROM config WHERE key = 'app_name');Error:
✗ ERROR: duplicate key value violates unique constraint
Solution: Add ON CONFLICT clause:
INSERT INTO users (email, name) VALUES (...)
ON CONFLICT (email) DO NOTHING;Error:
✗ ERROR: insert or update violates foreign key constraint
Solution: Ensure seeds run in correct order (dependencies first).
Error:
✗ Seed file not found: users
Solution:
# List available seeds
nself db seed --list
# Use correct name
nself db seed 01_usersSEEDS_DIR=custom/path nself db seed# Download and apply
curl https://example.com/seeds/demo.sql | nself db shell-- Only in development
DO $$
BEGIN
IF current_database() NOT LIKE '%prod%' THEN
INSERT INTO users (...) VALUES (...);
END IF;
END $$;-
nself db migrate- Apply schema changes before seeding -
nself db shell- Inspect seeded data -
nself db reset- Reset before re-seeding -
nself db backup- Backup after seeding
ɳSelf CLI v1.0.9. MIT licensed. Docs CC BY 4.0.
GitHub · Issues · Discussions · nself.org · docs.nself.org
Getting Started
Commands
- Commands, Overview
- Lifecycle: cmd-init · cmd-build · cmd-start · cmd-stop · cmd-restart · cmd-dev
- Monitoring: cmd-status · cmd-logs · cmd-health · cmd-urls · cmd-doctor · cmd-monitor · cmd-alerts · cmd-watchdog · cmd-dogfood
- Data: cmd-db · cmd-backup · cmd-dr · cmd-queue · cmd-webhooks
- Config: cmd-config · cmd-service · cmd-env · cmd-promote
- Networking: cmd-ssl · cmd-trust · cmd-dns-setup
- Security: cmd-security · cmd-secrets · cmd-waf
- Tenancy: cmd-tenant · cmd-billing
- Plugins: cmd-plugin · cmd-license
- AI: cmd-ai · cmd-claw · cmd-model
- Templates: cmd-template
- Utilities: cmd-exec · cmd-clean · cmd-reset · cmd-update · cmd-upgrade · cmd-version · cmd-admin · cmd-migrate · cmd-migrate-firebase · cmd-migrate-supabase · cmd-completion
Features
- Features, Overview
- Feature-Auth
- Feature-Storage
- Feature-Search
- Feature-Functions
- Feature-Email
- Feature-Monitoring
- Feature-Plugins
- Feature-ɳClaw, AI Assistant
- Feature-ɳChat, Messaging
- Feature-ɳTV, Media Player
- Feature-ɳFamily, Family Social
- Feature-ɳCloud, Managed Hosting
- Feature-Memory-Rooms, Knowledge Organization
- Feature-Agent-Dashboard, Agent Metrics
- Feature-Image-Generation, AI Image Generation
Configuration
- Configuration, Overview
- Config-Env-Vars
- Config-Postgres
- Config-Hasura
- Config-Auth
- Config-Nginx
- Config-Optional-Services
- Config-Custom-Services
- Config-System
Plugins (87 + 10 monitoring)
Free (25)
- plugin-backup
- plugin-content-acquisition
- plugin-content-progress
- plugin-cron
- plugin-donorbox
- plugin-feature-flags
- plugin-github
- plugin-github-runner
- plugin-invitations
- plugin-jobs
- plugin-link-preview
- plugin-mdns
- plugin-mlflow
- plugin-monitoring
- plugin-notifications
- plugin-notify
- plugin-paypal
- plugin-search
- plugin-shopify
- plugin-stripe
- plugin-subtitle-manager
- plugin-tokens
- plugin-torrent-manager
- plugin-vpn
- plugin-webhooks
Pro (62)
- plugin-access-controls
- plugin-activity-feed
- plugin-admin-api
- plugin-ai
- plugin-analytics
- plugin-auth
- plugin-backup-pro
- plugin-bots
- plugin-browser
- plugin-calendar
- plugin-cdn
- plugin-chat
- plugin-claw
- plugin-claw-budget
- plugin-claw-news
- plugin-claw-web
- plugin-cloudflare
- plugin-cms
- plugin-compliance
- plugin-cron-pro
- plugin-ddns
- plugin-devices
- plugin-documents
- plugin-donorbox-pro
- plugin-entitlements
- plugin-epg
- plugin-file-processing
- plugin-game-metadata
- plugin-geocoding
- plugin-geolocation
- plugin-google
- plugin-home
- plugin-idme
- plugin-knowledge-base
- plugin-linkedin
- plugin-livekit
- plugin-media-processing
- plugin-meetings
- plugin-moderation
- plugin-mux
- plugin-notify-pro
- plugin-object-storage
- plugin-observability
- plugin-paypal-pro
- plugin-photos
- plugin-podcast
- plugin-post
- plugin-realtime
- plugin-recording
- plugin-retro-gaming
- plugin-rom-discovery
- plugin-shopify-pro
- plugin-social
- plugin-sports
- plugin-stream-gateway
- plugin-streaming
- plugin-stripe-pro
- plugin-support
- plugin-tmdb
- plugin-voice
- plugin-web3
- plugin-workflows
Planned (26)
plugin-auditplugin-blogplugin-checkoutplugin-commerceplugin-drmplugin-exportplugin-flowplugin-importplugin-ldapplugin-mailgunplugin-mediaplugin-oauth-providersplugin-pagesplugin-postmarkplugin-rate-limitplugin-reportsplugin-samlplugin-schedulerplugin-sendgridplugin-ssoplugin-subscriptionplugin-thumbplugin-transcoderplugin-twilioplugin-wafplugin-watermark
Guides
- Guide-Production-Deployment
- Guide-SSL-Setup
- Guide-Multi-Tenancy
- Guide-Security-Hardening
- Guide-Monitoring-Setup
- Guide-Backup-Restore
- Guide-Custom-Services
- Guide-Migration-from-v1
Architecture
Reference
- API-Reference
- reference-error-codes, Error Codes
Licensing
Security
Brand
Operations
- operations/release-cascade, Release Cascade
- operations/self-healing, Self-Healing Schema
- operations/redis-tuning, Redis Pool Tuning
- operations/meilisearch-warmup, MeiliSearch Warm-Up
- operations/jwt-rotation, JWT Key Rotation
- operations/windows-wsl2-setup, Windows / WSL2 Setup
- operations/gemini-oauth-reauth, Gemini OAuth Reauth
Contributing
Admin
- USER-ACTION-QUEUE, Pending Admin Actions