trading-platform-database-v2/ddl/schemas/education/functions/01-update_updated_at.sql
rckrdmrd 45e77e9a9c feat: Initial commit - Database schemas and scripts
DDL schemas for Trading Platform:
- User management
- Authentication
- Payments
- Education
- ML predictions
- Trading data

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-18 04:30:23 -06:00

70 lines
2.3 KiB
PL/PgSQL

-- =====================================================
-- FUNCTION: education.update_updated_at_column()
-- =====================================================
-- Proyecto: OrbiQuant IA (Trading Platform)
-- Módulo: OQI-002 - Education
-- Especificación: ET-EDU-001-database.md
-- Descripción: Actualiza automáticamente el campo updated_at
-- =====================================================
CREATE OR REPLACE FUNCTION education.update_updated_at_column()
RETURNS TRIGGER AS $$
BEGIN
NEW.updated_at = NOW();
RETURN NEW;
END;
$$ LANGUAGE plpgsql;
COMMENT ON FUNCTION education.update_updated_at_column() IS 'Actualiza automáticamente updated_at en cada UPDATE';
-- Aplicar trigger a todas las tablas relevantes
CREATE TRIGGER update_categories_updated_at
BEFORE UPDATE ON education.categories
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_courses_updated_at
BEFORE UPDATE ON education.courses
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_modules_updated_at
BEFORE UPDATE ON education.modules
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_lessons_updated_at
BEFORE UPDATE ON education.lessons
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_enrollments_updated_at
BEFORE UPDATE ON education.enrollments
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_progress_updated_at
BEFORE UPDATE ON education.progress
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_quizzes_updated_at
BEFORE UPDATE ON education.quizzes
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_quiz_questions_updated_at
BEFORE UPDATE ON education.quiz_questions
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_user_gamification_profile_updated_at
BEFORE UPDATE ON education.user_gamification_profile
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();
CREATE TRIGGER update_course_reviews_updated_at
BEFORE UPDATE ON education.course_reviews
FOR EACH ROW
EXECUTE FUNCTION education.update_updated_at_column();