2026-04-17 12:16:56 -03:00
|
|
|
-- V013_ROLLBACK.sql
|
|
|
|
|
-- Reversa de V013__create_puntos_de_venta.sql.
|
|
|
|
|
--
|
2026-04-17 14:16:01 -03:00
|
|
|
-- ADVERTENCIA: ejecutar ELIMINA PuntoDeVenta, su historia temporal,
|
|
|
|
|
-- el permiso 'administracion:puntos_de_venta:gestionar' y sus asignaciones.
|
2026-04-17 12:16:56 -03:00
|
|
|
--
|
|
|
|
|
-- Uso intended: ROLLBACK en entornos NO-productivos.
|
|
|
|
|
-- Prerequisito: no deben existir FKs vivas apuntando a PuntoDeVenta (p.ej., comprobantes FAC-001).
|
|
|
|
|
-- Si FAC-001 ya está aplicado, este rollback fallará — usar backup.
|
2026-04-17 14:16:01 -03:00
|
|
|
--
|
|
|
|
|
-- NOTA: SecuenciaComprobante y SP usp_ReservarNumeroComprobante ya no forman parte
|
|
|
|
|
-- de V013 (eliminados en cirugía post-smoke Batch 9). Este rollback solo maneja PuntoDeVenta.
|
2026-04-17 12:16:56 -03:00
|
|
|
|
|
|
|
|
SET QUOTED_IDENTIFIER ON;
|
|
|
|
|
SET ANSI_NULLS ON;
|
|
|
|
|
SET NOCOUNT ON;
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
-- ═══════════════════════════════════════════════════════════════════════
|
2026-04-17 14:16:01 -03:00
|
|
|
-- 1. Apagar SYSTEM_VERSIONING + remover PERIOD — PuntoDeVenta
|
2026-04-17 12:16:56 -03:00
|
|
|
-- ═══════════════════════════════════════════════════════════════════════
|
|
|
|
|
|
|
|
|
|
IF EXISTS (SELECT 1 FROM sys.tables WHERE object_id = OBJECT_ID('dbo.PuntoDeVenta') AND temporal_type = 2)
|
|
|
|
|
BEGIN
|
|
|
|
|
ALTER TABLE dbo.PuntoDeVenta SET (SYSTEM_VERSIONING = OFF);
|
|
|
|
|
PRINT 'PuntoDeVenta: SYSTEM_VERSIONING OFF.';
|
|
|
|
|
END
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
IF EXISTS (SELECT 1 FROM sys.periods WHERE object_id = OBJECT_ID('dbo.PuntoDeVenta'))
|
|
|
|
|
BEGIN
|
|
|
|
|
ALTER TABLE dbo.PuntoDeVenta DROP PERIOD FOR SYSTEM_TIME;
|
|
|
|
|
PRINT 'PuntoDeVenta: PERIOD FOR SYSTEM_TIME dropped.';
|
|
|
|
|
END
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
IF COL_LENGTH('dbo.PuntoDeVenta', 'ValidFrom') IS NOT NULL
|
|
|
|
|
BEGIN
|
|
|
|
|
ALTER TABLE dbo.PuntoDeVenta DROP CONSTRAINT IF EXISTS DF_PuntoDeVenta_ValidFrom;
|
|
|
|
|
ALTER TABLE dbo.PuntoDeVenta DROP CONSTRAINT IF EXISTS DF_PuntoDeVenta_ValidTo;
|
|
|
|
|
ALTER TABLE dbo.PuntoDeVenta DROP COLUMN ValidFrom, ValidTo;
|
|
|
|
|
PRINT 'PuntoDeVenta: ValidFrom/ValidTo dropped.';
|
|
|
|
|
END
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
IF OBJECT_ID(N'dbo.PuntoDeVenta_History', N'U') IS NOT NULL
|
|
|
|
|
BEGIN
|
|
|
|
|
DROP TABLE dbo.PuntoDeVenta_History;
|
|
|
|
|
PRINT 'PuntoDeVenta_History dropped.';
|
|
|
|
|
END
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
-- ═══════════════════════════════════════════════════════════════════════
|
2026-04-17 14:16:01 -03:00
|
|
|
-- 2. Drop tabla PuntoDeVenta
|
2026-04-17 12:16:56 -03:00
|
|
|
-- ═══════════════════════════════════════════════════════════════════════
|
|
|
|
|
|
|
|
|
|
IF OBJECT_ID(N'dbo.PuntoDeVenta', N'U') IS NOT NULL
|
|
|
|
|
BEGIN
|
|
|
|
|
DROP TABLE dbo.PuntoDeVenta;
|
|
|
|
|
PRINT 'Table dbo.PuntoDeVenta dropped.';
|
|
|
|
|
END
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
-- ═══════════════════════════════════════════════════════════════════════
|
2026-04-17 14:16:01 -03:00
|
|
|
-- 3. Remover permiso 'administracion:puntos_de_venta:gestionar' + RolPermiso
|
2026-04-17 12:16:56 -03:00
|
|
|
-- ═══════════════════════════════════════════════════════════════════════
|
|
|
|
|
|
|
|
|
|
DELETE rp
|
|
|
|
|
FROM dbo.RolPermiso rp
|
|
|
|
|
JOIN dbo.Permiso p ON p.Id = rp.PermisoId
|
|
|
|
|
WHERE p.Codigo = 'administracion:puntos_de_venta:gestionar';
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
DELETE FROM dbo.Permiso
|
|
|
|
|
WHERE Codigo = 'administracion:puntos_de_venta:gestionar';
|
|
|
|
|
GO
|
|
|
|
|
|
|
|
|
|
PRINT '';
|
2026-04-17 14:16:01 -03:00
|
|
|
PRINT 'V013 rolled back. dbo.PuntoDeVenta and its history removed.';
|
2026-04-17 12:16:56 -03:00
|
|
|
PRINT 'Permiso administracion:puntos_de_venta:gestionar removed.';
|
|
|
|
|
GO
|