This commit is contained in:
2024-03-13 00:33:46 +01:00
commit e124a47765
19374 changed files with 9806149 additions and 0 deletions

View File

@@ -0,0 +1,117 @@
CREATE PROCEDURE [dbo].[sp_AddNewSchemaViews]
@IntezmenyId int,
@IntezmenyAzonosito nvarchar(20),
@TanevId int
AS
BEGIN
DECLARE @IntezmenyTemplate nvarchar(50) = 'KR_'+@IntezmenyAzonosito
DECLARE @Schema nvarchar(50) = @IntezmenyTemplate+'_Schema'
DECLARE @SchemaUser nvarchar(50) = @IntezmenyTemplate + '_user'
DECLARE @AktivTanev nvarchar(500)
DECLARE @Sql nvarchar(max)
-- IDE J<>NNEK AZ <20>J T<>BL<42>KHOZ TARTOZ<4F> VIEW-K
/*============================================================================*/
/* View : T_MUKODESIHELYTIPUS */
/*============================================================================*/
/* Package: Kreta */
IF OBJECT_ID('['+@Schema+'].T_MUKODESIHELYTIPUS', 'V') IS NOT NULL BEGIN
SET @Sql = N'EXEC sp_refreshview ''['+@Schema+'].T_MUKODESIHELYTIPUS'''
EXEC sp_executesql @Sql
IF OBJECT_ID('['+@Schema+'].T_MUKODESIHELYTIPUS_OSSZES', 'V') IS NOT NULL BEGIN
SET @Sql = N'EXEC sp_refreshview ''['+@Schema+'].T_MUKODESIHELYTIPUS_OSSZES'''
EXEC sp_executesql @Sql
END
END
ELSE BEGIN
/* Ha nem l<>tezik a view, akkor l<>trehozzuk */
IF (SELECT COUNT(1)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = N'T_MUKODESIHELYTIPUS' AND TABLE_SCHEMA = 'dbo' AND COLUMN_NAME = 'C_ALTANEVID'
) > 0
BEGIN
SET @AktivTanev = N' C_ALTANEVID = '+ CAST(@TanevId as nvarchar) +' AND '
END
ELSE
BEGIN
SET @AktivTanev = N''
END
IF (SELECT COUNT(1)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = N'T_MUKODESIHELYTIPUS' AND TABLE_SCHEMA = 'dbo' AND COLUMN_NAME = 'C_ALINTEZMENYID'
) > 0
BEGIN
/* T_MUKODESIHELYTIPUS */
SET @Sql = N'CREATE VIEW ['+@Schema+'].T_MUKODESIHELYTIPUS
AS
SELECT *
FROM dbo.T_MUKODESIHELYTIPUS
WHERE '+@AktivTanev+' (TOROLT = ''F'') AND C_ALINTEZMENYID = '+CAST(@IntezmenyId as nvarchar)
EXECUTE sp_executesql @Sql
/* T_MUKODESIHELYTIPUS_OSSZES */
SET @Sql = N'CREATE VIEW ['+@Schema+'].T_MUKODESIHELYTIPUS_OSSZES
AS
SELECT *
FROM dbo.T_MUKODESIHELYTIPUS
WHERE C_ALINTEZMENYID = '+CAST(@IntezmenyId as nvarchar)
EXECUTE sp_executesql @Sql
END
ELSE
BEGIN
/* T_MUKODESIHELYTIPUS */
SET @Sql = N'CREATE VIEW ['+@Schema+'].T_MUKODESIHELYTIPUS
AS
SELECT *
FROM dbo.T_MUKODESIHELYTIPUS
WHERE '+@AktivTanev+' (TOROLT = ''F'')'
EXECUTE sp_executesql @Sql
/* T_MUKODESIHELYTIPUS_OSSZES */
SET @Sql = N'CREATE VIEW ['+@Schema+'].T_MUKODESIHELYTIPUS_OSSZES
AS
SELECT *
FROM dbo.T_MUKODESIHELYTIPUS'
EXECUTE sp_executesql @Sql
END
END
END
GO
--------------------
DECLARE intezmenytanevekCursor CURSOR LOCAL FOR
SELECT T_INTEZMENY.ID, T_INTEZMENY.C_AZONOSITO, T_TANEV.ID
FROM T_INTEZMENY
INNER JOIN T_TANEV ON T_TANEV.C_INTEZMENYID = T_INTEZMENY.ID
WHERE T_TANEV.C_AKTIV = 'T' AND T_INTEZMENY.TOROLT = 'F'
ORDER BY T_INTEZMENY.ID
DECLARE @intezmenyId int, @intezmenyAzonosito nvarchar(20), @tanevId int
OPEN intezmenytanevekCursor
FETCH NEXT FROM intezmenytanevekCursor INTO @intezmenyId, @intezmenyAzonosito, @tanevId
WHILE @@FETCH_STATUS = 0
BEGIN
PRINT 'INT<EFBFBD>ZM<EFBFBD>NY ID: ' + CAST(@intezmenyId AS NVARCHAR(10)) + ', INT<4E>ZM<5A>NY AZONOS<4F>T<EFBFBD>: ' + CAST(@intezmenyAzonosito AS NVARCHAR(20)) + ', TAN<41>V ID: ' + CAST(@tanevId AS NVARCHAR(10))
EXEC sp_AddNewSchemaViews @IntezmenyId = @intezmenyId, @IntezmenyAzonosito = @intezmenyAzonosito, @TanevId = @tanevId
FETCH NEXT FROM intezmenytanevekCursor INTO @intezmenyId, @intezmenyAzonosito, @tanevId
END
CLOSE intezmenytanevekCursor
DEALLOCATE intezmenytanevekCursor
GO
--------------------
DROP PROCEDURE [dbo].[sp_AddNewSchemaViews]
GO

View File

@@ -0,0 +1,688 @@
GO
SET ANSI_NULLS, ANSI_PADDING, ANSI_WARNINGS, ARITHABORT, CONCAT_NULL_YIELDS_NULL, QUOTED_IDENTIFIER ON;
SET NUMERIC_ROUNDABORT OFF;
GO
PRINT N'Dropping [dbo].[FK_4026252_4026250]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELY] DROP CONSTRAINT [FK_4026252_4026250];
GO
PRINT N'Dropping [dbo].[FK_4026536_4026534]...';
GO
ALTER TABLE [dbo].[T_KIRTELEPHELY] DROP CONSTRAINT [FK_4026536_4026534];
GO
PRINT N'Dropping [dbo].[FK_4025687_4025686]...';
GO
ALTER TABLE [dbo].[T_CSENGETESIREND] DROP CONSTRAINT [FK_4025687_4025686];
GO
PRINT N'Dropping [dbo].[FK_4026032_4026030]...';
GO
ALTER TABLE [dbo].[T_FELADATELLATASIHELY] DROP CONSTRAINT [FK_4026032_4026030];
GO
PRINT N'Dropping [dbo].[FK_4025412_4025410]...';
GO
ALTER TABLE [dbo].[T_TEREM] DROP CONSTRAINT [FK_4025412_4025410];
GO
PRINT N'Starting rebuilding table [dbo].[T_INTEZMENYADATOK]...';
GO
BEGIN TRANSACTION;
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
SET XACT_ABORT ON;
CREATE TABLE [dbo].[tmp_ms_xx_T_INTEZMENYADATOK] (
[ID] INT IDENTITY (1, 1) NOT NULL,
[C_CIME] NVARCHAR (2000) NOT NULL,
[C_IGAZGATONEVE] NVARCHAR (255) NULL,
[C_NEV] NVARCHAR (255) NOT NULL,
[C_OMKOD] NVARCHAR (20) NOT NULL,
[C_TELEFONSZAM] NVARCHAR (20) NULL,
[C_EMAILCIM] NVARCHAR (255) NULL,
[C_IRANYITOSZAM] NVARCHAR (20) NOT NULL,
[C_VAROS] NVARCHAR (255) NOT NULL,
[C_ROVIDNEV] NVARCHAR (255) NULL,
[C_ADMINEMAILCIM] NVARCHAR (255) NULL,
[C_KRETATIPUS] INT NOT NULL,
[C_ENGEDELYEZETTALLASHELYEK] NUMERIC (10, 2) NULL,
[C_INTEZMENYHONLAPJA] NVARCHAR (300) NULL,
[C_AJTO] NVARCHAR (30) NULL,
[C_EMELET] NVARCHAR (40) NULL,
[C_HAZSZAM] NVARCHAR (30) NULL,
[C_KOZTERULETJELLEG] INT NULL,
[C_KOZTERULETNEV] NVARCHAR (40) NULL,
[C_TANEVID] INT NOT NULL,
[C_INTEZMENYID] INT NOT NULL,
[TOROLT] CHAR (1) DEFAULT ('F') NULL,
[SERIAL] INT NULL,
[LASTCHANGED] DATETIME DEFAULT (getdate()) NULL,
[CREATED] DATETIME DEFAULT (getdate()) NULL,
[MODIFIER] INT NULL,
[CREATOR] INT NULL,
[NNID] INT NULL,
CONSTRAINT [tmp_ms_xx_constraint_PK_T_40252091] PRIMARY KEY CLUSTERED ([ID] ASC)
);
IF EXISTS (SELECT TOP 1 1
FROM [dbo].[T_INTEZMENYADATOK])
BEGIN
SET IDENTITY_INSERT [dbo].[tmp_ms_xx_T_INTEZMENYADATOK] ON;
INSERT INTO [dbo].[tmp_ms_xx_T_INTEZMENYADATOK] ([ID], [C_CIME], [C_IGAZGATONEVE], [C_NEV], [C_OMKOD], [C_TELEFONSZAM], [C_EMAILCIM], [C_IRANYITOSZAM], [C_VAROS], [C_ROVIDNEV], [C_ADMINEMAILCIM], [C_KRETATIPUS], [C_ENGEDELYEZETTALLASHELYEK], [C_INTEZMENYHONLAPJA], [C_TANEVID], [C_INTEZMENYID], [TOROLT], [SERIAL], [LASTCHANGED], [CREATED], [MODIFIER], [CREATOR], [NNID])
SELECT [ID],
[C_CIME],
[C_IGAZGATONEVE],
[C_NEV],
[C_OMKOD],
[C_TELEFONSZAM],
[C_EMAILCIM],
[C_IRANYITOSZAM],
[C_VAROS],
[C_ROVIDNEV],
[C_ADMINEMAILCIM],
[C_KRETATIPUS],
[C_ENGEDELYEZETTALLASHELYEK],
[C_INTEZMENYHONLAPJA],
[C_TANEVID],
[C_INTEZMENYID],
[TOROLT],
[SERIAL],
[LASTCHANGED],
[CREATED],
[MODIFIER],
[CREATOR],
[NNID]
FROM [dbo].[T_INTEZMENYADATOK]
ORDER BY [ID] ASC;
SET IDENTITY_INSERT [dbo].[tmp_ms_xx_T_INTEZMENYADATOK] OFF;
END
DROP TABLE [dbo].[T_INTEZMENYADATOK];
EXECUTE sp_rename N'[dbo].[tmp_ms_xx_T_INTEZMENYADATOK]', N'T_INTEZMENYADATOK';
EXECUTE sp_rename N'[dbo].[tmp_ms_xx_constraint_PK_T_40252091]', N'PK_T_4025209', N'OBJECT';
COMMIT TRANSACTION;
SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
GO
PRINT N'Creating [dbo].[T_INTEZMENYADATOK].[I_T_4025209_4026340]...';
GO
CREATE NONCLUSTERED INDEX [I_T_4025209_4026340]
ON [dbo].[T_INTEZMENYADATOK]([C_INTEZMENYID] ASC, [C_TANEVID] ASC, [C_KRETATIPUS] ASC);
GO
PRINT N'Creating [dbo].[T_INTEZMENYADATOK].[I_T_4025209_4027515]...';
GO
CREATE NONCLUSTERED INDEX [I_T_4025209_4027515]
ON [dbo].[T_INTEZMENYADATOK]([C_INTEZMENYID] ASC, [C_TANEVID] ASC, [C_KOZTERULETJELLEG] ASC);
GO
PRINT N'Creating [dbo].[T_INTEZMENYADATOK].[I_T_4026244_4026243]...';
GO
CREATE NONCLUSTERED INDEX [I_T_4026244_4026243]
ON [dbo].[T_INTEZMENYADATOK]([C_TANEVID] ASC);
GO
PRINT N'Creating [dbo].[T_INTEZMENYADATOK].[I_T_4026248_4026247]...';
GO
CREATE NONCLUSTERED INDEX [I_T_4026248_4026247]
ON [dbo].[T_INTEZMENYADATOK]([C_INTEZMENYID] ASC);
GO
PRINT N'Starting rebuilding table [dbo].[T_MUKODESIHELY]...';
GO
BEGIN TRANSACTION;
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
SET XACT_ABORT ON;
CREATE TABLE [dbo].[tmp_ms_xx_T_MUKODESIHELY] (
[ID] INT IDENTITY (1, 1) NOT NULL,
[C_NEV] NVARCHAR (255) NOT NULL,
[C_CIME] NVARCHAR (1000) NULL,
[C_EMAILCIM] NVARCHAR (255) NULL,
[C_FAX] NVARCHAR (50) NULL,
[C_IRANYITOSZAM] NVARCHAR (20) NULL,
[C_TELEFONSZAM] NVARCHAR (50) NULL,
[C_VAROS] NVARCHAR (255) NULL,
[C_VEZETONEVE] NVARCHAR (255) NULL,
[C_TAGINTEZMENY] CHAR (1) DEFAULT ('F') NULL,
[C_TAGINTEZMENYIKOD] NVARCHAR (50) NULL,
[C_SZEKHELY] CHAR (1) DEFAULT ('F') NULL,
[C_AJTO] NVARCHAR (30) NULL,
[C_EMELET] NVARCHAR (40) NULL,
[C_HAZSZAM] NVARCHAR (30) NULL,
[C_KOZTERULETJELLEG] INT NULL,
[C_KOZTERULETNEV] NVARCHAR (40) NULL,
[C_MUKODESIHELYAZONOSITO] NVARCHAR (50) NULL,
[C_MUKODESIHELYTIPUSA] INT NULL,
[C_INTEZMENYADATOKID] INT NOT NULL,
[C_INTEZMENYID] INT NOT NULL,
[C_TANEVID] INT NOT NULL,
[TOROLT] CHAR (1) DEFAULT ('F') NULL,
[SERIAL] INT NULL,
[LASTCHANGED] DATETIME DEFAULT (getdate()) NULL,
[CREATED] DATETIME DEFAULT (getdate()) NULL,
[MODIFIER] INT NULL,
[CREATOR] INT NULL,
[NNID] INT NULL,
CONSTRAINT [tmp_ms_xx_constraint_PK_T_40251481] PRIMARY KEY CLUSTERED ([ID] ASC)
);
IF EXISTS (SELECT TOP 1 1
FROM [dbo].[T_MUKODESIHELY])
BEGIN
SET IDENTITY_INSERT [dbo].[tmp_ms_xx_T_MUKODESIHELY] ON;
INSERT INTO [dbo].[tmp_ms_xx_T_MUKODESIHELY] ([ID], [C_NEV], [C_CIME], [C_EMAILCIM], [C_FAX], [C_IRANYITOSZAM], [C_TELEFONSZAM], [C_VAROS], [C_VEZETONEVE], [C_TAGINTEZMENY], [C_TAGINTEZMENYIKOD], [C_SZEKHELY], [C_INTEZMENYADATOKID], [C_INTEZMENYID], [C_TANEVID], [TOROLT], [SERIAL], [LASTCHANGED], [CREATED], [MODIFIER], [CREATOR], [NNID])
SELECT [ID],
[C_NEV],
[C_CIME],
[C_EMAILCIM],
[C_FAX],
[C_IRANYITOSZAM],
[C_TELEFONSZAM],
[C_VAROS],
[C_VEZETONEVE],
[C_TAGINTEZMENY],
[C_TAGINTEZMENYIKOD],
[C_SZEKHELY],
[C_INTEZMENYADATOKID],
[C_INTEZMENYID],
[C_TANEVID],
[TOROLT],
[SERIAL],
[LASTCHANGED],
[CREATED],
[MODIFIER],
[CREATOR],
[NNID]
FROM [dbo].[T_MUKODESIHELY]
ORDER BY [ID] ASC;
SET IDENTITY_INSERT [dbo].[tmp_ms_xx_T_MUKODESIHELY] OFF;
END
DROP TABLE [dbo].[T_MUKODESIHELY];
EXECUTE sp_rename N'[dbo].[tmp_ms_xx_T_MUKODESIHELY]', N'T_MUKODESIHELY';
EXECUTE sp_rename N'[dbo].[tmp_ms_xx_constraint_PK_T_40251481]', N'PK_T_4025148', N'OBJECT';
COMMIT TRANSACTION;
SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
GO
PRINT N'Creating [dbo].[T_MUKODESIHELY].[I_T_4025148_4027508]...';
GO
CREATE NONCLUSTERED INDEX [I_T_4025148_4027508]
ON [dbo].[T_MUKODESIHELY]([C_INTEZMENYID] ASC, [C_TANEVID] ASC, [C_KOZTERULETJELLEG] ASC);
GO
PRINT N'Creating [dbo].[T_MUKODESIHELY].[I_T_4025148_4027511]...';
GO
CREATE NONCLUSTERED INDEX [I_T_4025148_4027511]
ON [dbo].[T_MUKODESIHELY]([C_INTEZMENYID] ASC, [C_TANEVID] ASC, [C_MUKODESIHELYTIPUSA] ASC);
GO
PRINT N'Creating [dbo].[T_MUKODESIHELY].[I_T_4026252_4026250]...';
GO
CREATE NONCLUSTERED INDEX [I_T_4026252_4026250]
ON [dbo].[T_MUKODESIHELY]([C_INTEZMENYADATOKID] ASC);
GO
PRINT N'Creating [dbo].[T_MUKODESIHELY].[I_T_402514802_402514800]...';
GO
CREATE NONCLUSTERED INDEX [I_T_402514802_402514800]
ON [dbo].[T_MUKODESIHELY]([C_INTEZMENYID] ASC);
GO
PRINT N'Creating [dbo].[T_MUKODESIHELY].[I_T_402514805_402514803]...';
GO
CREATE NONCLUSTERED INDEX [I_T_402514805_402514803]
ON [dbo].[T_MUKODESIHELY]([C_TANEVID] ASC);
GO
PRINT N'Creating [dbo].[T_MUKODESIHELY].[UK_4025200]...';
GO
CREATE UNIQUE NONCLUSTERED INDEX [UK_4025200]
ON [dbo].[T_MUKODESIHELY]([C_NEV] ASC, [C_INTEZMENYID] ASC, [C_TANEVID] ASC) WHERE ([TOROLT]='F');
GO
PRINT N'Creating [dbo].[FK_4025209_4026340]...';
GO
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH NOCHECK
ADD CONSTRAINT [FK_4025209_4026340] FOREIGN KEY ([C_KRETATIPUS], [C_INTEZMENYID], [C_TANEVID]) REFERENCES [dbo].[T_KRETATIPUS] ([ID], [C_ALINTEZMENYID], [C_ALTANEVID]);
GO
PRINT N'Creating [dbo].[FK_4026244_4026243]...';
GO
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH NOCHECK
ADD CONSTRAINT [FK_4026244_4026243] FOREIGN KEY ([C_TANEVID]) REFERENCES [dbo].[T_TANEV] ([ID]);
GO
PRINT N'Creating [dbo].[FK_4026248_4026247]...';
GO
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH NOCHECK
ADD CONSTRAINT [FK_4026248_4026247] FOREIGN KEY ([C_INTEZMENYID]) REFERENCES [dbo].[T_INTEZMENY] ([ID]);
GO
PRINT N'Creating [dbo].[FK_4026252_4026250]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH NOCHECK
ADD CONSTRAINT [FK_4026252_4026250] FOREIGN KEY ([C_INTEZMENYADATOKID]) REFERENCES [dbo].[T_INTEZMENYADATOK] ([ID]);
GO
PRINT N'Creating [dbo].[FK_4026536_4026534]...';
GO
ALTER TABLE [dbo].[T_KIRTELEPHELY] WITH NOCHECK
ADD CONSTRAINT [FK_4026536_4026534] FOREIGN KEY ([C_INTEZMENYADATOKID]) REFERENCES [dbo].[T_INTEZMENYADATOK] ([ID]);
GO
PRINT N'Creating [dbo].[FK_4025209_4027515]...';
GO
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH NOCHECK
ADD CONSTRAINT [FK_4025209_4027515] FOREIGN KEY ([C_KOZTERULETJELLEG], [C_INTEZMENYID], [C_TANEVID]) REFERENCES [dbo].[T_KOZTERULETJELLEG] ([ID], [C_ALINTEZMENYID], [C_ALTANEVID]);
GO
PRINT N'Creating [dbo].[FK_4025687_4025686]...';
GO
ALTER TABLE [dbo].[T_CSENGETESIREND] WITH NOCHECK
ADD CONSTRAINT [FK_4025687_4025686] FOREIGN KEY ([C_MUKODESIHELYID]) REFERENCES [dbo].[T_MUKODESIHELY] ([ID]);
GO
PRINT N'Creating [dbo].[FK_402514802_402514800]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH NOCHECK
ADD CONSTRAINT [FK_402514802_402514800] FOREIGN KEY ([C_INTEZMENYID]) REFERENCES [dbo].[T_INTEZMENY] ([ID]);
GO
PRINT N'Creating [dbo].[FK_402514805_402514803]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH NOCHECK
ADD CONSTRAINT [FK_402514805_402514803] FOREIGN KEY ([C_TANEVID]) REFERENCES [dbo].[T_TANEV] ([ID]);
GO
PRINT N'Creating [dbo].[FK_4026032_4026030]...';
GO
ALTER TABLE [dbo].[T_FELADATELLATASIHELY] WITH NOCHECK
ADD CONSTRAINT [FK_4026032_4026030] FOREIGN KEY ([C_MUKODESIHELYID]) REFERENCES [dbo].[T_MUKODESIHELY] ([ID]);
GO
PRINT N'Creating [dbo].[FK_4025412_4025410]...';
GO
ALTER TABLE [dbo].[T_TEREM] WITH NOCHECK
ADD CONSTRAINT [FK_4025412_4025410] FOREIGN KEY ([C_MUKODESIHELYID]) REFERENCES [dbo].[T_MUKODESIHELY] ([ID]);
GO
PRINT N'Creating [dbo].[FK_4025148_4027508]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH NOCHECK
ADD CONSTRAINT [FK_4025148_4027508] FOREIGN KEY ([C_KOZTERULETJELLEG], [C_INTEZMENYID], [C_TANEVID]) REFERENCES [dbo].[T_KOZTERULETJELLEG] ([ID], [C_ALINTEZMENYID], [C_ALTANEVID]);
GO
PRINT N'Creating [dbo].[FK_4025148_4027511]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH NOCHECK
ADD CONSTRAINT [FK_4025148_4027511] FOREIGN KEY ([C_MUKODESIHELYTIPUSA], [C_INTEZMENYID], [C_TANEVID]) REFERENCES [dbo].[T_MUKODESIHELYTIPUS] ([ID], [C_ALINTEZMENYID], [C_ALTANEVID]);
GO
PRINT N'Creating [dbo].[tr_intezmenyadatokLog]...';
GO
CREATE TRIGGER tr_intezmenyadatokLog ON T_INTEZMENYADATOK
FOR INSERT, DELETE, UPDATE AS
BEGIN
SET NOCOUNT ON
DECLARE
@insTable TABLE (objectId int, intezmenyId int, tanevId int, creator int, modifier int, col nvarchar(30), val varchar(max))
DECLARE
@delTable TABLE (objectId int, intezmenyId int, tanevId int, creator int, modifier int, col nvarchar(30), val varchar(max))
DECLARE
@linkTable TABLE (id int, objectId int, intezmenyId int, tanevId int)
DECLARE
@action char(1),
@xml xml
SET @action =
CASE
WHEN NOT EXISTS (SELECT 1 FROM DELETED) THEN 'I'
WHEN NOT EXISTS (SELECT 1 FROM INSERTED) THEN 'D'
ELSE 'U'
END
INSERT INTO @insTable (objectId, intezmenyId, tanevId, creator, modifier, col, val)
SELECT ID, C_INTEZMENYID, C_TANEVID, CREATOR, MODIFIER, col, val
FROM
(
SELECT ID, C_INTEZMENYID AS C_INTEZMENYID, C_TANEVID AS C_TANEVID, CREATOR, MODIFIER, CAST( C_CIME AS nvarchar(MAX)) AS C_CIME, CAST( C_IGAZGATONEVE AS nvarchar(MAX)) AS C_IGAZGATONEVE, CAST( C_NEV AS nvarchar(MAX)) AS C_NEV, CAST( C_OMKOD AS nvarchar(MAX)) AS C_OMKOD, CAST( C_TELEFONSZAM AS nvarchar(MAX)) AS C_TELEFONSZAM, CAST( C_EMAILCIM AS nvarchar(MAX)) AS C_EMAILCIM, CAST( C_IRANYITOSZAM AS nvarchar(MAX)) AS C_IRANYITOSZAM, CAST( C_VAROS AS nvarchar(MAX)) AS C_VAROS, CAST( C_ROVIDNEV AS nvarchar(MAX)) AS C_ROVIDNEV, CAST( C_ADMINEMAILCIM AS nvarchar(MAX)) AS C_ADMINEMAILCIM, CAST( C_KRETATIPUS AS nvarchar(MAX)) AS C_KRETATIPUS, CAST( C_ENGEDELYEZETTALLASHELYEK AS nvarchar(MAX)) AS C_ENGEDELYEZETTALLASHELYEK, CAST( C_INTEZMENYHONLAPJA AS nvarchar(MAX)) AS C_INTEZMENYHONLAPJA, CAST( C_AJTO AS nvarchar(MAX)) AS C_AJTO, CAST( C_EMELET AS nvarchar(MAX)) AS C_EMELET, CAST( C_HAZSZAM AS nvarchar(MAX)) AS C_HAZSZAM, CAST( C_KOZTERULETJELLEG AS nvarchar(MAX)) AS C_KOZTERULETJELLEG, CAST( C_KOZTERULETNEV AS nvarchar(MAX)) AS C_KOZTERULETNEV, CAST( TOROLT AS nvarchar(MAX)) AS TOROLT, CAST( NNID AS nvarchar(MAX)) AS NNID
FROM INSERTED) p
UNPIVOT (val FOR col IN (C_CIME, C_IGAZGATONEVE, C_NEV, C_OMKOD, C_TELEFONSZAM, C_EMAILCIM, C_IRANYITOSZAM, C_VAROS, C_ROVIDNEV, C_ADMINEMAILCIM, C_KRETATIPUS, C_ENGEDELYEZETTALLASHELYEK, C_INTEZMENYHONLAPJA, C_AJTO, C_EMELET, C_HAZSZAM, C_KOZTERULETJELLEG, C_KOZTERULETNEV, TOROLT, NNID)) AS unpvt
INSERT INTO @delTable (objectId, intezmenyId, tanevId, creator, modifier, col, val)
SELECT ID, C_INTEZMENYID, C_TANEVID, CREATOR, MODIFIER, col, val
FROM
(
SELECT ID, C_INTEZMENYID AS C_INTEZMENYID, C_TANEVID AS C_TANEVID, CREATOR, MODIFIER, CAST( C_CIME AS nvarchar(MAX)) AS C_CIME, CAST( C_IGAZGATONEVE AS nvarchar(MAX)) AS C_IGAZGATONEVE, CAST( C_NEV AS nvarchar(MAX)) AS C_NEV, CAST( C_OMKOD AS nvarchar(MAX)) AS C_OMKOD, CAST( C_TELEFONSZAM AS nvarchar(MAX)) AS C_TELEFONSZAM, CAST( C_EMAILCIM AS nvarchar(MAX)) AS C_EMAILCIM, CAST( C_IRANYITOSZAM AS nvarchar(MAX)) AS C_IRANYITOSZAM, CAST( C_VAROS AS nvarchar(MAX)) AS C_VAROS, CAST( C_ROVIDNEV AS nvarchar(MAX)) AS C_ROVIDNEV, CAST( C_ADMINEMAILCIM AS nvarchar(MAX)) AS C_ADMINEMAILCIM, CAST( C_KRETATIPUS AS nvarchar(MAX)) AS C_KRETATIPUS, CAST( C_ENGEDELYEZETTALLASHELYEK AS nvarchar(MAX)) AS C_ENGEDELYEZETTALLASHELYEK, CAST( C_INTEZMENYHONLAPJA AS nvarchar(MAX)) AS C_INTEZMENYHONLAPJA, CAST( C_AJTO AS nvarchar(MAX)) AS C_AJTO, CAST( C_EMELET AS nvarchar(MAX)) AS C_EMELET, CAST( C_HAZSZAM AS nvarchar(MAX)) AS C_HAZSZAM, CAST( C_KOZTERULETJELLEG AS nvarchar(MAX)) AS C_KOZTERULETJELLEG, CAST( C_KOZTERULETNEV AS nvarchar(MAX)) AS C_KOZTERULETNEV, CAST( TOROLT AS nvarchar(MAX)) AS TOROLT, CAST( NNID AS nvarchar(MAX)) AS NNID
FROM DELETED) p
UNPIVOT (val FOR col IN (C_CIME, C_IGAZGATONEVE, C_NEV, C_OMKOD, C_TELEFONSZAM, C_EMAILCIM, C_IRANYITOSZAM, C_VAROS, C_ROVIDNEV, C_ADMINEMAILCIM, C_KRETATIPUS, C_ENGEDELYEZETTALLASHELYEK, C_INTEZMENYHONLAPJA, C_AJTO, C_EMELET, C_HAZSZAM, C_KOZTERULETJELLEG, C_KOZTERULETNEV, TOROLT, NNID)) AS unpvt
IF @action = 'I' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), objectId, 'T_INTEZMENYADATOK', 'New', creator, intezmenyId, tanevId FROM @insTable
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT val, NULL, col, lk.id
FROM @insTable i
INNER JOIN @linkTable lk ON i.objectId = lk.objectId AND i.intezmenyId = lk.intezmenyId AND i.tanevId = lk.tanevId
END
IF @action = 'D' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), objectId, 'T_INTEZMENYADATOK', 'Removed', modifier, intezmenyId, tanevId FROM @delTable
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT val, NULL, col, lk.id
FROM @delTable i
INNER JOIN @linkTable lk ON i.objectId = lk.objectId AND i.intezmenyId = lk.intezmenyId AND i.tanevId = lk.tanevId
END
IF @action = 'U' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), i.objectId, 'T_INTEZMENYADATOK',
CASE
WHEN i.val = 'T' AND d.val = 'F' THEN 'Logical Removed'
WHEN i.val = 'F' AND d.val = 'T' THEN 'Restored'
ELSE 'Modified'
END, i.modifier, i.intezmenyId, i.tanevId
FROM @insTable i
INNER JOIN @delTable d ON i.intezmenyId = d.intezmenyId AND i.objectId = d.objectId AND i.tanevId = d.tanevId AND i.col = d.col
WHERE i.col = 'TOROLT' AND d.COL = 'TOROLT'
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT i.val, d.val, ISNULL(i.col, d.col), lk.id
FROM @delTable d
FULL JOIN @insTable i ON i.objectId = d.objectId AND i.intezmenyId = d.intezmenyId AND i.tanevId = d.tanevId AND i.col = d.col
INNER JOIN @linkTable lk ON ISNULL(i.objectId, d.objectId) = lk.objectId AND ISNULL(i.intezmenyId, d.intezmenyId) = lk.intezmenyId AND ISNULL(i.tanevId, d.tanevId) = lk.tanevId
WHERE (i.val <> d.val OR ((i.val IS NULL OR d.val IS NULL) AND (i.val IS NOT NULL OR d.val IS NOT NULL)))
END
END
GO
PRINT N'Creating [dbo].[tr_mukodesihelyLog]...';
GO
CREATE TRIGGER tr_mukodesihelyLog ON T_MUKODESIHELY
FOR INSERT, DELETE, UPDATE AS
BEGIN
SET NOCOUNT ON
DECLARE
@insTable TABLE (objectId int, intezmenyId int, tanevId int, creator int, modifier int, col nvarchar(30), val varchar(max))
DECLARE
@delTable TABLE (objectId int, intezmenyId int, tanevId int, creator int, modifier int, col nvarchar(30), val varchar(max))
DECLARE
@linkTable TABLE (id int, objectId int, intezmenyId int, tanevId int)
DECLARE
@action char(1),
@xml xml
SET @action =
CASE
WHEN NOT EXISTS (SELECT 1 FROM DELETED) THEN 'I'
WHEN NOT EXISTS (SELECT 1 FROM INSERTED) THEN 'D'
ELSE 'U'
END
INSERT INTO @insTable (objectId, intezmenyId, tanevId, creator, modifier, col, val)
SELECT ID, C_INTEZMENYID, C_TANEVID, CREATOR, MODIFIER, col, val
FROM
(
SELECT ID, C_INTEZMENYID AS C_INTEZMENYID, C_TANEVID AS C_TANEVID, CREATOR, MODIFIER, CAST( C_NEV AS nvarchar(MAX)) AS C_NEV, CAST( C_CIME AS nvarchar(MAX)) AS C_CIME, CAST( C_EMAILCIM AS nvarchar(MAX)) AS C_EMAILCIM, CAST( C_FAX AS nvarchar(MAX)) AS C_FAX, CAST( C_IRANYITOSZAM AS nvarchar(MAX)) AS C_IRANYITOSZAM, CAST( C_TELEFONSZAM AS nvarchar(MAX)) AS C_TELEFONSZAM, CAST( C_VAROS AS nvarchar(MAX)) AS C_VAROS, CAST( C_VEZETONEVE AS nvarchar(MAX)) AS C_VEZETONEVE, CAST( C_TAGINTEZMENY AS nvarchar(MAX)) AS C_TAGINTEZMENY, CAST( C_TAGINTEZMENYIKOD AS nvarchar(MAX)) AS C_TAGINTEZMENYIKOD, CAST( C_SZEKHELY AS nvarchar(MAX)) AS C_SZEKHELY, CAST( C_AJTO AS nvarchar(MAX)) AS C_AJTO, CAST( C_EMELET AS nvarchar(MAX)) AS C_EMELET, CAST( C_HAZSZAM AS nvarchar(MAX)) AS C_HAZSZAM, CAST( C_KOZTERULETJELLEG AS nvarchar(MAX)) AS C_KOZTERULETJELLEG, CAST( C_KOZTERULETNEV AS nvarchar(MAX)) AS C_KOZTERULETNEV, CAST( C_MUKODESIHELYAZONOSITO AS nvarchar(MAX)) AS C_MUKODESIHELYAZONOSITO, CAST( C_MUKODESIHELYTIPUSA AS nvarchar(MAX)) AS C_MUKODESIHELYTIPUSA, CAST( C_INTEZMENYADATOKID AS nvarchar(MAX)) AS C_INTEZMENYADATOKID, CAST( TOROLT AS nvarchar(MAX)) AS TOROLT, CAST( NNID AS nvarchar(MAX)) AS NNID
FROM INSERTED) p
UNPIVOT (val FOR col IN (C_NEV, C_CIME, C_EMAILCIM, C_FAX, C_IRANYITOSZAM, C_TELEFONSZAM, C_VAROS, C_VEZETONEVE, C_TAGINTEZMENY, C_TAGINTEZMENYIKOD, C_SZEKHELY, C_AJTO, C_EMELET, C_HAZSZAM, C_KOZTERULETJELLEG, C_KOZTERULETNEV, C_MUKODESIHELYAZONOSITO, C_MUKODESIHELYTIPUSA, C_INTEZMENYADATOKID, TOROLT, NNID)) AS unpvt
INSERT INTO @delTable (objectId, intezmenyId, tanevId, creator, modifier, col, val)
SELECT ID, C_INTEZMENYID, C_TANEVID, CREATOR, MODIFIER, col, val
FROM
(
SELECT ID, C_INTEZMENYID AS C_INTEZMENYID, C_TANEVID AS C_TANEVID, CREATOR, MODIFIER, CAST( C_NEV AS nvarchar(MAX)) AS C_NEV, CAST( C_CIME AS nvarchar(MAX)) AS C_CIME, CAST( C_EMAILCIM AS nvarchar(MAX)) AS C_EMAILCIM, CAST( C_FAX AS nvarchar(MAX)) AS C_FAX, CAST( C_IRANYITOSZAM AS nvarchar(MAX)) AS C_IRANYITOSZAM, CAST( C_TELEFONSZAM AS nvarchar(MAX)) AS C_TELEFONSZAM, CAST( C_VAROS AS nvarchar(MAX)) AS C_VAROS, CAST( C_VEZETONEVE AS nvarchar(MAX)) AS C_VEZETONEVE, CAST( C_TAGINTEZMENY AS nvarchar(MAX)) AS C_TAGINTEZMENY, CAST( C_TAGINTEZMENYIKOD AS nvarchar(MAX)) AS C_TAGINTEZMENYIKOD, CAST( C_SZEKHELY AS nvarchar(MAX)) AS C_SZEKHELY, CAST( C_AJTO AS nvarchar(MAX)) AS C_AJTO, CAST( C_EMELET AS nvarchar(MAX)) AS C_EMELET, CAST( C_HAZSZAM AS nvarchar(MAX)) AS C_HAZSZAM, CAST( C_KOZTERULETJELLEG AS nvarchar(MAX)) AS C_KOZTERULETJELLEG, CAST( C_KOZTERULETNEV AS nvarchar(MAX)) AS C_KOZTERULETNEV, CAST( C_MUKODESIHELYAZONOSITO AS nvarchar(MAX)) AS C_MUKODESIHELYAZONOSITO, CAST( C_MUKODESIHELYTIPUSA AS nvarchar(MAX)) AS C_MUKODESIHELYTIPUSA, CAST( C_INTEZMENYADATOKID AS nvarchar(MAX)) AS C_INTEZMENYADATOKID, CAST( TOROLT AS nvarchar(MAX)) AS TOROLT, CAST( NNID AS nvarchar(MAX)) AS NNID
FROM DELETED) p
UNPIVOT (val FOR col IN (C_NEV, C_CIME, C_EMAILCIM, C_FAX, C_IRANYITOSZAM, C_TELEFONSZAM, C_VAROS, C_VEZETONEVE, C_TAGINTEZMENY, C_TAGINTEZMENYIKOD, C_SZEKHELY, C_AJTO, C_EMELET, C_HAZSZAM, C_KOZTERULETJELLEG, C_KOZTERULETNEV, C_MUKODESIHELYAZONOSITO, C_MUKODESIHELYTIPUSA, C_INTEZMENYADATOKID, TOROLT, NNID)) AS unpvt
IF @action = 'I' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), objectId, 'T_MUKODESIHELY', 'New', creator, intezmenyId, tanevId FROM @insTable
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT val, NULL, col, lk.id
FROM @insTable i
INNER JOIN @linkTable lk ON i.objectId = lk.objectId AND i.intezmenyId = lk.intezmenyId AND i.tanevId = lk.tanevId
END
IF @action = 'D' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), objectId, 'T_MUKODESIHELY', 'Removed', modifier, intezmenyId, tanevId FROM @delTable
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT val, NULL, col, lk.id
FROM @delTable i
INNER JOIN @linkTable lk ON i.objectId = lk.objectId AND i.intezmenyId = lk.intezmenyId AND i.tanevId = lk.tanevId
END
IF @action = 'U' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), i.objectId, 'T_MUKODESIHELY',
CASE
WHEN i.val = 'T' AND d.val = 'F' THEN 'Logical Removed'
WHEN i.val = 'F' AND d.val = 'T' THEN 'Restored'
ELSE 'Modified'
END, i.modifier, i.intezmenyId, i.tanevId
FROM @insTable i
INNER JOIN @delTable d ON i.intezmenyId = d.intezmenyId AND i.objectId = d.objectId AND i.tanevId = d.tanevId AND i.col = d.col
WHERE i.col = 'TOROLT' AND d.COL = 'TOROLT'
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT i.val, d.val, ISNULL(i.col, d.col), lk.id
FROM @delTable d
FULL JOIN @insTable i ON i.objectId = d.objectId AND i.intezmenyId = d.intezmenyId AND i.tanevId = d.tanevId AND i.col = d.col
INNER JOIN @linkTable lk ON ISNULL(i.objectId, d.objectId) = lk.objectId AND ISNULL(i.intezmenyId, d.intezmenyId) = lk.intezmenyId AND ISNULL(i.tanevId, d.tanevId) = lk.tanevId
WHERE (i.val <> d.val OR ((i.val IS NULL OR d.val IS NULL) AND (i.val IS NOT NULL OR d.val IS NOT NULL)))
END
END
GO
PRINT N'Refreshing [dbo].[T_INTEZMENYADATOK_OSSZES]...';
GO
EXECUTE sp_refreshsqlmodule N'[dbo].[T_INTEZMENYADATOK_OSSZES]';
GO
PRINT N'Refreshing [dbo].[T_MUKODESIHELY_OSSZES]...';
GO
EXECUTE sp_refreshsqlmodule N'[dbo].[T_MUKODESIHELY_OSSZES]';
GO
PRINT N'Checking existing data against newly created constraints';
GO
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH CHECK CHECK CONSTRAINT [FK_4025209_4026340];
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH CHECK CHECK CONSTRAINT [FK_4026244_4026243];
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH CHECK CHECK CONSTRAINT [FK_4026248_4026247];
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH CHECK CHECK CONSTRAINT [FK_4026252_4026250];
ALTER TABLE [dbo].[T_KIRTELEPHELY] WITH CHECK CHECK CONSTRAINT [FK_4026536_4026534];
ALTER TABLE [dbo].[T_INTEZMENYADATOK] WITH CHECK CHECK CONSTRAINT [FK_4025209_4027515];
ALTER TABLE [dbo].[T_CSENGETESIREND] WITH CHECK CHECK CONSTRAINT [FK_4025687_4025686];
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH CHECK CHECK CONSTRAINT [FK_402514802_402514800];
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH CHECK CHECK CONSTRAINT [FK_402514805_402514803];
ALTER TABLE [dbo].[T_FELADATELLATASIHELY] WITH CHECK CHECK CONSTRAINT [FK_4026032_4026030];
ALTER TABLE [dbo].[T_TEREM] WITH CHECK CHECK CONSTRAINT [FK_4025412_4025410];
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH CHECK CHECK CONSTRAINT [FK_4025148_4027508];
ALTER TABLE [dbo].[T_MUKODESIHELY] WITH CHECK CHECK CONSTRAINT [FK_4025148_4027511];
GO
PRINT N'Update complete.';
GO
PRINT '--- intézményi view-k (dbo táblákkal megegyező nevű és a tábla_OSSZES nevűek) frissítése ---'
DECLARE @viewname nvarchar(100), @pureview nvarchar(100)
DECLARE semaviewk CURSOR LOCAL FOR
SELECT '['+TABLE_SCHEMA + '].[' + TABLE_NAME + ']', TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'VIEW' and TABLE_SCHEMA LIKE 'KR[_]%[_]Schema'
AND TABLE_NAME in (
'T_INTEZMENYADATOK', 'T_INTEZMENYADATOK_OSSZES',
'T_MUKODESIHELY', 'T_MUKODESIHELY_OSSZES'
) -- ha csak néhány VIEW frissült, akkor a gyorsabb futásért ide fel lehet sorolni
ORDER BY TABLE_SCHEMA, TABLE_NAME
OPEN semaviewk
FETCH NEXT FROM semaviewk INTO @viewname, @pureview
WHILE @@FETCH_STATUS = 0 BEGIN
PRINT @viewname
EXEC sp_refreshview @viewname
FETCH NEXT FROM semaviewk INTO @viewname, @pureview
END
CLOSE semaviewk
DEALLOCATE semaviewk
GO

View File

@@ -0,0 +1,213 @@
GO
SET ANSI_NULLS, ANSI_PADDING, ANSI_WARNINGS, ARITHABORT, CONCAT_NULL_YIELDS_NULL, QUOTED_IDENTIFIER ON;
SET NUMERIC_ROUNDABORT OFF;
GO
PRINT N'Creating [dbo].[T_MUKODESIHELYTIPUS]...';
GO
CREATE TABLE [dbo].[T_MUKODESIHELYTIPUS] (
[ID] INT NOT NULL,
[C_ALINTEZMENYID] INT NOT NULL,
[C_ALTANEVID] INT NOT NULL,
[TOROLT] CHAR (1) NULL,
[SERIAL] INT NULL,
[LASTCHANGED] DATETIME NULL,
[CREATED] DATETIME NULL,
[MODIFIER] INT NULL,
[CREATOR] INT NULL,
[NNID] INT NULL,
CONSTRAINT [PK_T_4027504] PRIMARY KEY CLUSTERED ([ID] ASC, [C_ALINTEZMENYID] ASC, [C_ALTANEVID] ASC)
);
GO
PRINT N'Creating [dbo].[T_MUKODESIHELYTIPUS].[I_T_402750402_402750400]...';
GO
CREATE NONCLUSTERED INDEX [I_T_402750402_402750400]
ON [dbo].[T_MUKODESIHELYTIPUS]([C_ALINTEZMENYID] ASC);
GO
PRINT N'Creating [dbo].[T_MUKODESIHELYTIPUS].[I_T_402750405_402750403]...';
GO
CREATE NONCLUSTERED INDEX [I_T_402750405_402750403]
ON [dbo].[T_MUKODESIHELYTIPUS]([C_ALTANEVID] ASC);
GO
PRINT N'Creating unnamed constraint on [dbo].[T_MUKODESIHELYTIPUS]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS]
ADD DEFAULT ('F') FOR [TOROLT];
GO
PRINT N'Creating unnamed constraint on [dbo].[T_MUKODESIHELYTIPUS]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS]
ADD DEFAULT (getdate()) FOR [LASTCHANGED];
GO
PRINT N'Creating unnamed constraint on [dbo].[T_MUKODESIHELYTIPUS]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS]
ADD DEFAULT (getdate()) FOR [CREATED];
GO
PRINT N'Creating [dbo].[FK_T_21038_4027517]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS] WITH NOCHECK
ADD CONSTRAINT [FK_T_21038_4027517] FOREIGN KEY ([ID], [C_ALINTEZMENYID], [C_ALTANEVID]) REFERENCES [dbo].[T_DICTIONARYITEMBASE] ([ID], [C_INTEZMENYID], [C_TANEVID]);
GO
PRINT N'Creating [dbo].[FK_402750402_402750400]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS] WITH NOCHECK
ADD CONSTRAINT [FK_402750402_402750400] FOREIGN KEY ([C_ALINTEZMENYID]) REFERENCES [dbo].[T_INTEZMENY] ([ID]);
GO
PRINT N'Creating [dbo].[FK_402750405_402750403]...';
GO
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS] WITH NOCHECK
ADD CONSTRAINT [FK_402750405_402750403] FOREIGN KEY ([C_ALTANEVID]) REFERENCES [dbo].[T_TANEV] ([ID]);
GO
PRINT N'Creating [dbo].[tr_mukodesihelytipusLog]...';
GO
CREATE TRIGGER tr_mukodesihelytipusLog ON T_MUKODESIHELYTIPUS
FOR INSERT, DELETE, UPDATE AS
BEGIN
SET NOCOUNT ON
DECLARE
@insTable TABLE (objectId int, intezmenyId int, tanevId int, creator int, modifier int, col nvarchar(30), val varchar(max))
DECLARE
@delTable TABLE (objectId int, intezmenyId int, tanevId int, creator int, modifier int, col nvarchar(30), val varchar(max))
DECLARE
@linkTable TABLE (id int, objectId int, intezmenyId int, tanevId int)
DECLARE
@action char(1),
@xml xml
SET @action =
CASE
WHEN NOT EXISTS (SELECT 1 FROM DELETED) THEN 'I'
WHEN NOT EXISTS (SELECT 1 FROM INSERTED) THEN 'D'
ELSE 'U'
END
INSERT INTO @insTable (objectId, intezmenyId, tanevId, creator, modifier, col, val)
SELECT ID, C_INTEZMENYID, C_TANEVID, CREATOR, MODIFIER, col, val
FROM
(
SELECT ID, C_ALINTEZMENYID AS C_INTEZMENYID, C_ALTANEVID AS C_TANEVID, CREATOR, MODIFIER, CAST( TOROLT AS nvarchar(MAX)) AS TOROLT, CAST( NNID AS nvarchar(MAX)) AS NNID
FROM INSERTED) p
UNPIVOT (val FOR col IN (TOROLT, NNID)) AS unpvt
INSERT INTO @delTable (objectId, intezmenyId, tanevId, creator, modifier, col, val)
SELECT ID, C_INTEZMENYID, C_TANEVID, CREATOR, MODIFIER, col, val
FROM
(
SELECT ID, C_ALINTEZMENYID AS C_INTEZMENYID, C_ALTANEVID AS C_TANEVID, CREATOR, MODIFIER, CAST( TOROLT AS nvarchar(MAX)) AS TOROLT, CAST( NNID AS nvarchar(MAX)) AS NNID
FROM DELETED) p
UNPIVOT (val FOR col IN (TOROLT, NNID)) AS unpvt
IF @action = 'I' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), objectId, 'T_MUKODESIHELYTIPUS', 'New', creator, intezmenyId, tanevId FROM @insTable
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT val, NULL, col, lk.id
FROM @insTable i
INNER JOIN @linkTable lk ON i.objectId = lk.objectId AND i.intezmenyId = lk.intezmenyId AND i.tanevId = lk.tanevId
END
IF @action = 'D' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), objectId, 'T_MUKODESIHELYTIPUS', 'Removed', modifier, intezmenyId, tanevId FROM @delTable
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT val, NULL, col, lk.id
FROM @delTable i
INNER JOIN @linkTable lk ON i.objectId = lk.objectId AND i.intezmenyId = lk.intezmenyId AND i.tanevId = lk.tanevId
END
IF @action = 'U' BEGIN
INSERT INTO T_ENTITYHISTORY (C_ALTERATIONDATE, C_ENTITYID, C_ENTITYNAME, C_REASON, C_FELHASZNALOID, C_INTEZMENYID, C_TANEVID)
OUTPUT INSERTED.ID, INSERTED.C_ENTITYID, INSERTED.C_INTEZMENYID, INSERTED.C_TANEVID INTO @linkTable
SELECT DISTINCT GETDATE(), i.objectId, 'T_MUKODESIHELYTIPUS',
CASE
WHEN i.val = 'T' AND d.val = 'F' THEN 'Logical Removed'
WHEN i.val = 'F' AND d.val = 'T' THEN 'Restored'
ELSE 'Modified'
END, i.modifier, i.intezmenyId, i.tanevId
FROM @insTable i
INNER JOIN @delTable d ON i.intezmenyId = d.intezmenyId AND i.objectId = d.objectId AND i.tanevId = d.tanevId AND i.col = d.col
WHERE i.col = 'TOROLT' AND d.COL = 'TOROLT'
INSERT INTO T_ENTITYATTRIBUTEHISTORY (C_CURRENTVALUE, C_ORIGINALVALUE, C_PROPERTYNAME, C_ENTITYHISTORYID)
SELECT i.val, d.val, ISNULL(i.col, d.col), lk.id
FROM @delTable d
FULL JOIN @insTable i ON i.objectId = d.objectId AND i.intezmenyId = d.intezmenyId AND i.tanevId = d.tanevId AND i.col = d.col
INNER JOIN @linkTable lk ON ISNULL(i.objectId, d.objectId) = lk.objectId AND ISNULL(i.intezmenyId, d.intezmenyId) = lk.intezmenyId AND ISNULL(i.tanevId, d.tanevId) = lk.tanevId
WHERE (i.val <> d.val OR ((i.val IS NULL OR d.val IS NULL) AND (i.val IS NOT NULL OR d.val IS NOT NULL)))
END
END
GO
PRINT N'Creating [dbo].[T_MUKODESIHELYTIPUS_OSSZES]...';
GO
CREATE VIEW dbo.T_MUKODESIHELYTIPUS_OSSZES
AS
SELECT *
FROM dbo.T_MUKODESIHELYTIPUS
GO
PRINT N'Checking existing data against newly created constraints';
GO
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS] WITH CHECK CHECK CONSTRAINT [FK_T_21038_4027517];
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS] WITH CHECK CHECK CONSTRAINT [FK_402750402_402750400];
ALTER TABLE [dbo].[T_MUKODESIHELYTIPUS] WITH CHECK CHECK CONSTRAINT [FK_402750405_402750403];
GO
PRINT N'Update complete.';
GO

View File

@@ -0,0 +1,21 @@
DECLARE intezmenytanevekCursor CURSOR LOCAL FOR
SELECT C_INTEZMENYID, C_TANEVID
FROM T_INTEZMENYADATOK
--WHERE TOROLT = 'F'
DECLARE @intezmenyId int, @tanevId int
OPEN intezmenytanevekCursor
FETCH NEXT FROM intezmenytanevekCursor INTO @intezmenyId, @tanevId
WHILE @@FETCH_STATUS = 0
BEGIN
PRINT 'INT<EFBFBD>ZM<EFBFBD>NY ID: ' + CAST(@intezmenyId AS NVARCHAR(10)) + ', TAN<41>V ID: ' + CAST(@tanevId AS NVARCHAR(10))
EXEC sp_Global_CreateDictionaryItems @IntezmenyId = @intezmenyId, @TanevId = @tanevId
FETCH NEXT FROM intezmenytanevekCursor INTO @intezmenyId, @tanevId
END
CLOSE intezmenytanevekCursor
DEALLOCATE intezmenytanevekCursor