gohorsejobs/backend/migrations/017_create_tickets_table.sql
Tiago Yamamoto 568b4ebb88 refactor: clean up legacy UUID v4, use UUID v7 everywhere
Migrations:
- 016, 017, 019: Replace gen_random_uuid() with uuid_generate_v7()
- All UUID tables now use custom uuid_generate_v7() function

Backend:
- Create internal/utils/uuid/uuid.go with V7() function (RFC 9562)
- Update storage_handler.go to use internal uuid.V7()
- Remove dependency on google/uuid for file naming

All new UUIDs in the system are now UUID v7 (time-ordered)
2025-12-24 11:29:55 -03:00

25 lines
1,000 B
SQL

DROP TABLE IF EXISTS ticket_messages;
DROP TABLE IF EXISTS tickets;
CREATE TABLE tickets (
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
user_id INTEGER NOT NULL REFERENCES users(id) ON DELETE CASCADE,
subject VARCHAR(255) NOT NULL,
status VARCHAR(50) NOT NULL DEFAULT 'open', -- open, in_progress, closed
priority VARCHAR(50) NOT NULL DEFAULT 'medium', -- low, medium, high
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE INDEX idx_tickets_user_id ON tickets(user_id);
CREATE INDEX idx_tickets_status ON tickets(status);
CREATE TABLE ticket_messages (
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
ticket_id UUID NOT NULL REFERENCES tickets(id) ON DELETE CASCADE,
user_id INTEGER NOT NULL REFERENCES users(id) ON DELETE CASCADE, -- Sender
message TEXT NOT NULL,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
CREATE INDEX idx_ticket_messages_ticket_id ON ticket_messages(ticket_id);