Files
DUTAS/SqlAgent/v1/03_Prod/1_Database_Setup/CreateDB.sql
2025-10-20 08:03:45 -04:00

64 lines
1.9 KiB
Transact-SQL

-- Create the database
CREATE DATABASE ProdDUTASJobSchedule;
GO
USE ProdDUTASJobSchedule;
GO
-- Create the main control table
CREATE TABLE dbo.JobControl (
JobID INT IDENTITY(1,1) PRIMARY KEY,
JobName VARCHAR(50) NOT NULL UNIQUE,
ScheduledStartTime TIME NOT NULL,
SchedulerAction VARCHAR(10) NOT NULL CHECK (SchedulerAction IN ('CONTINUE', 'STOP')),
IsActive BIT DEFAULT 1,
CreatedDate DATETIME DEFAULT GETDATE(),
Frequency VARCHAR(20) NOT NULL
);
GO
-- Create job dependencies table
CREATE TABLE dbo.JobDependencies (
DependencyID INT IDENTITY(1,1) PRIMARY KEY,
JobName VARCHAR(50) NOT NULL,
PredecessorJobName VARCHAR(50) NULL,
FOREIGN KEY (JobName) REFERENCES dbo.JobControl(JobName)
);
GO
-- Create execution history table
CREATE TABLE dbo.JobExecutionHistory (
ExecutionID INT IDENTITY(1,1) PRIMARY KEY,
JobName VARCHAR(50) NOT NULL,
RunDate DATE NOT NULL,
ScheduledStartTime TIME NOT NULL,
ActualStartTime DATETIME NULL,
ActualEndTime DATETIME NULL,
Status VARCHAR(20) DEFAULT 'Pending' CHECK (Status IN ('Pending', 'Running', 'Success', 'Failed', 'ForceComplete')),
ErrorMessage VARCHAR(MAX) NULL,
OverrideFlag BIT DEFAULT 0,
OverrideBy VARCHAR(100) NULL,
OverrideDate DATETIME NULL
);
GO
-- Create holidays table
CREATE TABLE dbo.FederalHolidays (
HolidayID INT IDENTITY(1,1) PRIMARY KEY,
HolidayDate DATE NOT NULL UNIQUE,
HolidayName VARCHAR(100) NOT NULL,
Year INT NOT NULL
);
GO
-- Create Exit Code table for PowerShell Script
CREATE TABLE dbo.JobExitCodes
(
JobExecutionID INT IDENTITY(1,1) PRIMARY KEY, -- unique ID per execution
JobName NVARCHAR(128) NOT NULL, -- job name
RunDate DATE NOT NULL, -- date of execution
ExitCode INT NOT NULL, -- exit code from job
RecordedTime DATETIME NOT NULL DEFAULT GETDATE() -- timestamp of execution
);
GO