Fix: Ejecutar schema antes de seed en botón de carga de datos
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 1m4s
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 1m4s
- Endpoint seed-database ahora ejecuta 01_schema.sql primero - Luego ejecuta 02_seed.sql - Resuelve error cuando se presiona seed después de borrar BD - Schema tiene CREATE TABLE IF NOT EXISTS (idempotente) Flujo correcto: 1. Borrar BD → DROP TABLE de todo 2. Cargar datos → Crea tablas + inserta datos
This commit is contained in:
@@ -22,13 +22,21 @@ export default defineEventHandler(async (event) => {
|
||||
const client = await getClient()
|
||||
|
||||
try {
|
||||
// Leer el archivo de seed
|
||||
// Leer los archivos SQL
|
||||
const schemaPath = join(process.cwd(), 'server', 'database', '01_schema.sql')
|
||||
const seedPath = join(process.cwd(), 'server', 'database', '02_seed.sql')
|
||||
|
||||
const schemaSQL = await readFile(schemaPath, 'utf-8')
|
||||
const seedSQL = await readFile(seedPath, 'utf-8')
|
||||
|
||||
await client.query('BEGIN')
|
||||
|
||||
// Ejecutar el script completo de seed
|
||||
// Primero ejecutar schema (crea tablas si no existen)
|
||||
console.log('📋 Ejecutando schema...')
|
||||
await client.query(schemaSQL)
|
||||
|
||||
// Luego ejecutar seed (inserta datos de ejemplo)
|
||||
console.log('📋 Ejecutando seed...')
|
||||
await client.query(seedSQL)
|
||||
|
||||
await client.query('COMMIT')
|
||||
@@ -37,7 +45,7 @@ export default defineEventHandler(async (event) => {
|
||||
|
||||
return {
|
||||
success: true,
|
||||
message: 'Datos de ejemplo cargados: 10 lotes, 7 operaciones, 16 relaciones',
|
||||
message: 'Schema recreado y datos de ejemplo cargados: 10 lotes, 7 operaciones, 16 relaciones',
|
||||
}
|
||||
} catch (error) {
|
||||
await client.query('ROLLBACK')
|
||||
|
||||
Reference in New Issue
Block a user