-- ============================================================================= -- openPG Data Structures for SQL Server -- -- Tennessee Valley Authority, 2009 -- No copyright is claimed pursuant to 17 USC § 105. All Other Rights Reserved. -- -- Mehulbhai P Thakkar -- 05/23/2011 -- Script is based on openPDC.sql script created by James Ritchie Carroll. -- ============================================================================= USE [master] GO CREATE DATABASE [openPG]; GO ALTER DATABASE [openPG] SET ANSI_NULL_DEFAULT OFF GO ALTER DATABASE [openPG] SET ANSI_NULLS OFF GO ALTER DATABASE [openPG] SET ANSI_PADDING OFF GO ALTER DATABASE [openPG] SET ANSI_WARNINGS OFF GO ALTER DATABASE [openPG] SET ARITHABORT OFF GO ALTER DATABASE [openPG] SET AUTO_CLOSE OFF GO ALTER DATABASE [openPG] SET AUTO_CREATE_STATISTICS ON GO ALTER DATABASE [openPG] SET AUTO_SHRINK OFF GO ALTER DATABASE [openPG] SET AUTO_UPDATE_STATISTICS ON GO ALTER DATABASE [openPG] SET CURSOR_CLOSE_ON_COMMIT OFF GO ALTER DATABASE [openPG] SET CURSOR_DEFAULT GLOBAL GO ALTER DATABASE [openPG] SET CONCAT_NULL_YIELDS_NULL OFF GO ALTER DATABASE [openPG] SET NUMERIC_ROUNDABORT OFF GO ALTER DATABASE [openPG] SET QUOTED_IDENTIFIER OFF GO ALTER DATABASE [openPG] SET RECURSIVE_TRIGGERS OFF GO ALTER DATABASE [openPG] SET ENABLE_BROKER GO ALTER DATABASE [openPG] SET AUTO_UPDATE_STATISTICS_ASYNC OFF GO ALTER DATABASE [openPG] SET DATE_CORRELATION_OPTIMIZATION OFF GO ALTER DATABASE [openPG] SET TRUSTWORTHY OFF GO ALTER DATABASE [openPG] SET ALLOW_SNAPSHOT_ISOLATION OFF GO ALTER DATABASE [openPG] SET PARAMETERIZATION SIMPLE GO ALTER DATABASE [openPG] SET READ_WRITE GO ALTER DATABASE [openPG] SET RECOVERY SIMPLE GO ALTER DATABASE [openPG] SET MULTI_USER GO ALTER DATABASE [openPG] SET PAGE_VERIFY CHECKSUM GO ALTER DATABASE [openPG] SET DB_CHAINING OFF GO -- The next three commented statements are used to create a user with access to the openPG database. -- Be sure to change the username and password. -- Replace-all from NewUser to the desired username is the preferred method of changing the username. --IF NOT EXISTS (SELECT * FROM sys.server_principals WHERE name = N'NewUser') --CREATE LOGIN [NewUser] WITH PASSWORD=N'MyPassword', DEFAULT_DATABASE=[master], CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF --GO USE [openPG] GO --CREATE USER [NewUser] FOR LOGIN [NewUser] --GO --CREATE ROLE [openPGManagerRole] AUTHORIZATION [dbo] --GO --EXEC sp_addrolemember N'openPGManagerRole', N'NewUser' --GO --EXEC sp_addrolemember N'db_datareader', N'openPGManagerRole' --GO --EXEC sp_addrolemember N'db_datawriter', N'openPGManagerRole' --GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[ErrorLog]( [ID] [int] IDENTITY(1,1) NOT NULL, [Source] [varchar](200) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, [Type] [varchar](200) COLLATE SQL_Latin1_General_CP1_CI_AS NULL, [Message] [varchar](max) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, [Detail] [varchar](max) COLLATE SQL_Latin1_General_CP1_CI_AS NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_ErrorLog_CreatedOn] DEFAULT (getutcdate()), CONSTRAINT [PK_ErrorLog] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] CREATE TABLE [dbo].[Runtime]( [ID] [int] IDENTITY(1,1) NOT NULL, [SourceID] [int] NOT NULL, [SourceTable] [varchar](200) NOT NULL, CONSTRAINT [PK_Runtime] PRIMARY KEY CLUSTERED ( [SourceID] ASC, [SourceTable] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO CREATE UNIQUE NONCLUSTERED INDEX [IX_Runtime] ON [dbo].[Runtime] ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[AuditLog]( [ID] [int] IDENTITY(1,1) NOT NULL, [TableName] [varchar](200) NOT NULL, [PrimaryKeyColumn] [varchar](200) NOT NULL, [PrimaryKeyValue] [varchar](max) NOT NULL, [ColumnName] [varchar](200) NOT NULL, [OriginalValue] [varchar](max) NULL, [NewValue] [varchar](max) NULL, [Deleted] [bit] NOT NULL CONSTRAINT [DF_AuditLog_Deleted] DEFAULT ((0)), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_AuditLog_UpdatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_AuditLog_UpdatedOn] DEFAULT (getutcdate()), CONSTRAINT [PK_AuditLog] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Company]( [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](200) NOT NULL, [MapAcronym] [nchar](3) NOT NULL, [Name] [varchar](200) NOT NULL, [URL] [varchar](max) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_Company_LoadOrder] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Company_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Company_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Company_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Company_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Company] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[ConfigurationEntity]( [SourceName] [varchar](200) NOT NULL, [RuntimeName] [varchar](200) NOT NULL, [Description] [varchar](max) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_ConfigurationEntity_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_ConfigurationEntity_Enabled] DEFAULT ((0)) ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Vendor]( [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](200) NULL, [Name] [varchar](200) NOT NULL, [PhoneNumber] [varchar](200) NULL, [ContactEmail] [varchar](200) NULL, [URL] [varchar](max) NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Vendor_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Vendor_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Vendor_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Vendor_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Vendor] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Protocol]( [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](200) NOT NULL, [Name] [varchar](200) NOT NULL, [Type] [varchar](200) NOT NULL CONSTRAINT [DF_Protocol_Type] DEFAULT (N'Frame'), [Category] [varchar](200) NOT NULL CONSTRAINT [DF_Protocol_Category] DEFAULT (N'Phasor'), [AssemblyName] [varchar] (1024) NOT NULL CONSTRAINT [DF_Protocol_AssemblyName] DEFAULT (N'TVA.PhasorProtocols.dll'), [TypeName] [varchar] (200) NOT NULL CONSTRAINT [DF_Protocol_TypeName] DEFAULT (N'TVA.PhasorProtocols.PhasorMeasurementMapper'), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_Protocol_LoadOrder] DEFAULT ((0)), CONSTRAINT [PK_Protocol] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[SignalType]( [ID] [int] IDENTITY(1,1) NOT NULL, [Name] [varchar](200) NOT NULL, [Acronym] [varchar](4) NOT NULL, [Suffix] [varchar](2) NOT NULL, [Abbreviation] [varchar](2) NOT NULL, [Source] [varchar](10) NOT NULL, [EngineeringUnits] [varchar](10) NULL, CONSTRAINT [PK_SignalType] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Interconnection]( [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](50) NOT NULL, [Name] [varchar](100) NOT NULL, [LoadOrder] [int] NULL CONSTRAINT [DF_Interconnection_LoadOrder] DEFAULT ((0)), CONSTRAINT [PK_Interconnection] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[OtherDevice]( [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](200) NOT NULL, [Name] [varchar](200) NULL, [IsConcentrator] [bit] NOT NULL CONSTRAINT [DF_OtherDevices_IsConcentrator] DEFAULT ((0)), [CompanyID] [int] NULL, [VendorDeviceID] [int] NULL, [Longitude] [decimal](9, 6) NULL, [Latitude] [decimal](9, 6) NULL, [InterconnectionID] [int] NULL, [Planned] [bit] NOT NULL CONSTRAINT [DF_OtherDevices_Planned] DEFAULT ((0)), [Desired] [bit] NOT NULL CONSTRAINT [DF_OtherDevices_Desired] DEFAULT ((0)), [InProgress] [bit] NOT NULL CONSTRAINT [DF_OtherDevices_InProgress] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_OtherDevice_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OtherDevice_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_OtherDevice_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OtherDevice_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_OtherDevice] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Node]( [ID] [uniqueidentifier] NOT NULL CONSTRAINT [DF_Node_ID] DEFAULT (newid()), [Name] [varchar](200) NOT NULL, [CompanyID] [int] NULL, [Longitude] [decimal](9, 6) NULL, [Latitude] [decimal](9, 6) NULL, [Description] [varchar](max) NULL, [ImagePath] [varchar](max) NULL, [Settings] [varchar] (max) NULL, [MenuType] [varchar] (200) NOT NULL CONSTRAINT [DF_Node_MenuType] DEFAULT (N'File'), [MenuData] [varchar](max) NOT NULL CONSTRAINT [DF_Node_MenuData] DEFAULT (N'Menu.xml'), [Master] [bit] NOT NULL CONSTRAINT [DF_Node_Master] DEFAULT ((0)), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_Node_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_Node_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Node_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Node_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Node_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Node_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Node] PRIMARY KEY NONCLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO CREATE UNIQUE NONCLUSTERED INDEX [IX_Node_Name] ON [dbo].[Node] ( [Name] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[DataOperation]( [NodeID] [uniqueidentifier] NULL, [Description] [varchar](max) NULL, [AssemblyName] [varchar](max) NOT NULL, [TypeName] [varchar](max) NOT NULL, [MethodName] [varchar](200) NOT NULL, [Arguments] [varchar](max) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_DataOperation_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_DataOperation_Enabled] DEFAULT ((0)) ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Device]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [ParentID] [int] NULL, [UniqueID] [uniqueidentifier] NOT NULL CONSTRAINT [DF_Device_UniqueID] DEFAULT (newid()), [Acronym] [varchar](200) NOT NULL, [Name] [varchar](200) NULL, [OriginalSource] [varchar](200) NULL, [IsConcentrator] [bit] NOT NULL CONSTRAINT [DF_Device_IsConcentrator] DEFAULT ((0)), [CompanyID] [int] NULL, [HistorianID] [int] NULL, [AccessID] [int] NOT NULL CONSTRAINT [DF_Device_AccessID] DEFAULT ((0)), [VendorDeviceID] [int] NULL, [ProtocolID] [int] NULL, [Longitude] [decimal](9, 6) NULL, [Latitude] [decimal](9, 6) NULL, [InterconnectionID] [int] NULL, [ConnectionString] [varchar](max) NULL, [TimeZone] [varchar](200) NULL, [FramesPerSecond] [int] NULL DEFAULT ((30)), [TimeAdjustmentTicks] [bigint] NOT NULL CONSTRAINT [DF_Device_TimeAdjustmentTicks] DEFAULT ((0)), [DataLossInterval] [float] NOT NULL CONSTRAINT [DF_Device_DataLossInterval] DEFAULT ((5)), [AllowedParsingExceptions] [int] NOT NULL CONSTRAINT [DF_Device_AllowedParsingExceptions] DEFAULT ((10)), [ParsingExceptionWindow] [float] NOT NULL CONSTRAINT [DF_Device_ParsingExceptionWindow] DEFAULT ((5)), [DelayedConnectionInterval] [float] NOT NULL CONSTRAINT [DF_Device_DelayedConnectionInterval] DEFAULT ((5)), [AllowUseOfCachedConfiguration] [bit] NOT NULL CONSTRAINT [DF_Device_AllowUseOfCachedConfiguration] DEFAULT ((1)), [AutoStartDataParsingSequence] [bit] NOT NULL CONSTRAINT [DF_Device_AutoStartDataParsingSequence] DEFAULT ((1)), [SkipDisableRealTimeData] [bit] NOT NULL CONSTRAINT [DF_Device_SkipDisableRealTimeData] DEFAULT ((0)), [MeasurementReportingInterval] [int] NOT NULL CONSTRAINT [DF_Device_MeasurementReportingInterval] DEFAULT ((100000)), [ConnectOnDemand] [bit] NOT NULL CONSTRAINT [DF_Device_ConnectOnDemand] DEFAULT((1)), [ContactList] [nvarchar](max) NULL, [MeasuredLines] [int] NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_Device_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_Device_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Device_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](50) NOT NULL CONSTRAINT [DF_Device_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Device_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](50) NOT NULL CONSTRAINT [DF_Device_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Device] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO CREATE UNIQUE NONCLUSTERED INDEX [IX_Device_Acronym] ON [dbo].[Device] ( [NodeID] ASC, [Acronym] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO /* This trigger after INSERT and DELETE on [dbo].[Device_RuntimeSync] performs INSERT and DELETE on [dbo].[Runtime] table. */ CREATE TRIGGER [dbo].[Device_RuntimeSync] ON [dbo].[Device] AFTER INSERT, DELETE AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- If a new record has been added IF EXISTS(SELECT * FROM INSERTED) BEGIN INSERT INTO Runtime (SourceID, SourceTable) SELECT ID, 'Device' FROM INSERTED END -- If a record has been deleted IF EXISTS(SELECT * FROM DELETED) BEGIN DELETE FROM Runtime WHERE SourceID IN (SELECT ID FROM DELETED) AND SourceTable = 'Device' END END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[VendorDevice]( [ID] [int] IDENTITY(1,1) NOT NULL, [VendorID] [int] NOT NULL CONSTRAINT [DF_VendorDevice_VendorID] DEFAULT ((10)), [Name] [varchar](200) NOT NULL, [Description] [varchar](max) NULL, [URL] [varchar](max) NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_VendorDevice_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_VendorDevice_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_VendorDevice_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_VendorDevice_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_VendorDevice] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[OutputStreamDeviceDigital]( [NodeID] [uniqueidentifier] NOT NULL, [OutputStreamDeviceID] [int] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [Label] [varchar](max) NOT NULL, [MaskValue] [int] NOT NULL CONSTRAINT [DF_OutputStreamDeviceDigital_MaskValue] DEFAULT ((0)), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_OutputStreamDeviceDigital_LoadOrder] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDeviceDigital_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDeviceDigital_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDeviceDigital_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDeviceDigital_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_OutputStreamDeviceDigital] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[OutputStreamDevicePhasor]( [NodeID] [uniqueidentifier] NOT NULL, [OutputStreamDeviceID] [int] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [Label] [varchar](200) NOT NULL, [Type] [nchar](1) NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_Type] DEFAULT (N'V'), [Phase] [nchar](1) NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_Phase] DEFAULT (N'+'), [ScalingValue] [int] NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_ScalingValue] DEFAULT ((0)), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_LoadOrder] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDevicePhasor_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_OutputStreamDevicePhasor] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[OutputStreamDeviceAnalog]( [NodeID] [uniqueidentifier] NOT NULL, [OutputStreamDeviceID] [int] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [Label] [varchar](16) NOT NULL, [Type] [int] NOT NULL CONSTRAINT [DF_OutputStreamDeviceAnalog_Type] DEFAULT ((0)), [ScalingValue] [int] NOT NULL CONSTRAINT [DF_OutputStreamDeviceAnalog_ScalingValue] DEFAULT ((0)), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_OutputStreamDeviceAnalog_LoadOrder] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDeviceAnalog_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDeviceAnalog_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDeviceAnalog_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDeviceAnalog_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_OutputStreamDeviceAnalog] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Measurement]( [PointID] [int] IDENTITY(1,1) NOT NULL, [SignalID] [uniqueidentifier] NOT NULL CONSTRAINT [DF_Measurement_SignalID] DEFAULT (newid()), [HistorianID] [int] NULL, [DeviceID] [int] NULL, [PointTag] [varchar](200) NOT NULL, [AlternateTag] [varchar](max) NULL, [SignalTypeID] [int] NOT NULL, [PhasorSourceIndex] [int] NULL, [SignalReference] [varchar](200) NOT NULL, [Adder] [float] NOT NULL CONSTRAINT [DF_Measurement_Adder] DEFAULT ((0.0)), [Multiplier] [float] NOT NULL CONSTRAINT [DF_Measurement_Multiplier] DEFAULT ((1.0)), [Description] [varchar](max) NULL, [Internal] [bit] NOT NULL CONSTRAINT [DF_Measurement_Internal] DEFAULT ((1)), [Subscribed] [bit] NOT NULL CONSTRAINT [DF_Measurement_Subscribed] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_Measurement_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Measurement_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Measurement_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Measurement_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Measurement_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Measurement] PRIMARY KEY CLUSTERED ( [SignalID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO CREATE UNIQUE NONCLUSTERED INDEX [IX_Measurement_PointID] ON [dbo].[Measurement] ( [PointID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[ImportedMeasurement]( [NodeID] [uniqueidentifier] NULL, [SourceNodeID] [uniqueidentifier] NULL, [SignalID] [uniqueidentifier] NULL, [Source] [varchar](200) NOT NULL, [PointID] [int] NOT NULL, [PointTag] [varchar](200) NOT NULL, [AlternateTag] [varchar](200) NULL, [SignalTypeAcronym] [varchar](4) NULL, [SignalReference] [varchar](200) NOT NULL, [FramesPerSecond] [int] NULL, [ProtocolAcronym] [varchar](200) NULL, [ProtocolType] [varchar](200) NOT NULL CONSTRAINT [DF_ImportedMeasurement_ProtocolType] DEFAULT ('Frame'), [PhasorID] [int] NULL, [PhasorType] [nchar](1) NULL, [Phase] [nchar](1) NULL, [Adder] [float] NOT NULL CONSTRAINT [DF_ImportedMeasurement_Adder] DEFAULT ((0.0)), [Multiplier] [float] NOT NULL CONSTRAINT [DF_ImportedMeasurement_Multiplier] DEFAULT ((1.0)), [CompanyAcronym] [varchar](200) NULL, [Longitude] [decimal](9,6) NULL, [Latitude] [decimal](9,6) NULL, [Description] [varchar](max) NULL, [Enabled] [bit] NOT NULL CONSTRAINT [DF_ImportedMeasurement_Enabled] DEFAULT ((0)) ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Statistic]( [ID] [int] IDENTITY(1,1) NOT NULL, [Source] [varchar](20) NOT NULL, [SignalIndex] [int] NOT NULL, [Name] [varchar](200) NOT NULL, [Description] [varchar](max) NULL, [AssemblyName] [varchar](max) NOT NULL, [TypeName] [varchar](max) NOT NULL, [MethodName] [varchar](200) NOT NULL, [Arguments] [varchar](max) NULL, [Enabled] [bit] NOT NULL CONSTRAINT [DF_Statistic_Enabled] DEFAULT ((0)), [DataType] [varchar](200) NULL, [DisplayFormat] [varchar](200) NULL, [IsConnectedState] [bit] NOT NULL CONSTRAINT [DF_Statistic_IsConnectedState] DEFAULT ((0)), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_Statistic_LoadOrder] DEFAULT ((0)), CONSTRAINT [PK_Statistic] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO CREATE UNIQUE NONCLUSTERED INDEX [IX_Statistic_Source_SignalIndex] ON [dbo].[Statistic] ( [Source] ASC, [SignalIndex] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[OutputStreamMeasurement]( [NodeID] [uniqueidentifier] NOT NULL, [AdapterID] [int] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [HistorianID] [int] NULL, [PointID] [int] NOT NULL, [SignalReference] [varchar](200) NOT NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamMeasurement_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamMeasurement_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamMeasurement_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamMeasurement_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_OutputStreamMeasurement] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[OutputStreamDevice]( [NodeID] [uniqueidentifier] NOT NULL, [AdapterID] [int] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [IDCode] [int] NOT NULL CONSTRAINT [DF_OutputStreamDevices_IDCode] DEFAULT ((0)), [Acronym] [varchar](200) NOT NULL, [BpaAcronym] [varchar](4) NULL, [Name] [varchar](200) NOT NULL, [PhasorDataFormat] [varchar](15) NULL, [FrequencyDataFormat] [varchar](15) NULL, [AnalogDataFormat] [varchar](15) NULL, [CoordinateFormat] [varchar](15) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_OutputStreamDevices_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_OutputStreamDevices_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDevice_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDevice_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStreamDevice_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStreamDevice_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_OutputStreamDevice] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Phasor]( [ID] [int] IDENTITY(1,1) NOT NULL, [DeviceID] [int] NOT NULL, [Label] [varchar](200) NOT NULL, [Type] [nchar](1) NOT NULL CONSTRAINT [DF_Phasor_Type] DEFAULT (N'V'), [Phase] [nchar](1) NOT NULL CONSTRAINT [DF_Phasor_Phase] DEFAULT (N'+'), [DestinationPhasorID] [int] NULL, [SourceIndex] [int] NOT NULL CONSTRAINT [DF_Phasor_SourceIndex] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Phasor_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Phasor_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Phasor_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Phasor_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Phasor] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[CalculatedMeasurement]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](200) NOT NULL, [Name] [varchar](200) NULL, [AssemblyName] [varchar](max) NOT NULL, [TypeName] [varchar](max) NOT NULL, [ConnectionString] [varchar](max) NULL, [ConfigSection] [varchar](200) NULL, [InputMeasurements] [varchar](max) NULL, [OutputMeasurements] [varchar](max) NULL, [MinimumMeasurementsToUse] [int] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_MinimumMeasurementsToUse] DEFAULT ((-1)), [FramesPerSecond] [int] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_FramesPerSecond] DEFAULT ((30)), [LagTime] [float] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_LagTime] DEFAULT ((3.0)), [LeadTime] [float] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_LeadTime] DEFAULT ((1.0)), [UseLocalClockAsRealTime] [bit] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_UseLocalClockAsRealTime] DEFAULT ((0)), [AllowSortsByArrival] [bit] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_AllowSortsByArrival] DEFAULT ((1)), [IgnoreBadTimeStamps] [bit] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_IgnoreBadTimeStamps] DEFAULT ((0)), [TimeResolution] [int] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_TimeResolution] DEFAULT ((10000)), [AllowPreemptivePublishing] [bit] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_AllowPreemptivePublishing] DEFAULT ((1)), [PerformTimeReasonabilityCheck] [bit] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_PerformTimestampReasonabilityCheck] DEFAULT ((1)), [DownsamplingMethod] [varchar](15) NOT NULL CONSTRAINT [DF_CalculatedMeasurement_DownsamplingMethod] DEFAULT (N'LastReceived'), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CalculatedMeasurement_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_CalculatedMeasurement_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CalculatedMeasurement_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_CalculatedMeasurement] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TRIGGER [dbo].[CalculatedMeasurement_RuntimeSync] ON [dbo].[CalculatedMeasurement] AFTER INSERT, DELETE AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- If a new record has been added IF EXISTS(SELECT * FROM INSERTED) BEGIN INSERT INTO Runtime (SourceID, SourceTable) SELECT ID, 'CalculatedMeasurement' FROM INSERTED END -- If a record has been deleted IF EXISTS(SELECT * FROM DELETED) BEGIN DELETE FROM Runtime WHERE SourceID IN (SELECT ID FROM DELETED) AND SourceTable = 'CalculatedMeasurement' END END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[CustomActionAdapter]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [AdapterName] [varchar](200) NOT NULL, [AssemblyName] [varchar](max) NOT NULL, [TypeName] [varchar](max) NOT NULL, [ConnectionString] [varchar](max) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_CustomActionAdapter_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_CustomActionAdapter_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_CustomActionAdapter_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CustomActionAdapter_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_CustomActionAdapter_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CustomActionAdapter_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_CustomActionAdapter] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TRIGGER [dbo].[CustomActionAdapter_RuntimeSync] ON [dbo].[CustomActionAdapter] AFTER INSERT, DELETE AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- If a new record has been added IF EXISTS(SELECT * FROM INSERTED) BEGIN INSERT INTO Runtime (SourceID, SourceTable) SELECT ID, 'CustomActionAdapter' FROM INSERTED END -- If a record has been deleted IF EXISTS(SELECT * FROM DELETED) BEGIN DELETE FROM Runtime WHERE SourceID IN (SELECT ID FROM DELETED) AND SourceTable = 'CustomActionAdapter' END END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Historian]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](200) NOT NULL, [Name] [varchar](200) NULL, [AssemblyName] [varchar](max) NULL, [TypeName] [varchar](max) NULL, [ConnectionString] [varchar](max) NULL, [IsLocal] [bit] NOT NULL CONSTRAINT [DF_Historian_IsLocal] DEFAULT ((1)), [MeasurementReportingInterval] [int] NOT NULL CONSTRAINT [DF_Historian_MeasurementReportingInterval] DEFAULT ((100000)), [Description] [varchar](max) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_Historian_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_Historian_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Historian_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Historian_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Historian_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Historian_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Historian] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TRIGGER [dbo].[Historian_RuntimeSync] ON [dbo].[Historian] AFTER INSERT, DELETE AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- If a new record has been added IF EXISTS(SELECT * FROM INSERTED) BEGIN INSERT INTO Runtime (SourceID, SourceTable) SELECT ID, 'Historian' FROM INSERTED END -- If a record has been deleted IF EXISTS(SELECT * FROM DELETED) BEGIN DELETE FROM Runtime WHERE SourceID IN (SELECT ID FROM DELETED) AND SourceTable = 'Historian' END END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[CustomInputAdapter]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [AdapterName] [varchar](200) NOT NULL, [AssemblyName] [varchar](max) NOT NULL, [TypeName] [varchar](max) NOT NULL, [ConnectionString] [varchar](max) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_CustomInputAdapter_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_CustomInputAdapter_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_CustomInputAdapter_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CustomInputAdapter_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_CustomInputAdapter_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CustomInputAdapter_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_CustomInputAdapter] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TRIGGER [dbo].[CustomInputAdapter_RuntimeSync] ON [dbo].[CustomInputAdapter] AFTER INSERT, DELETE AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- If a new record has been added IF EXISTS(SELECT * FROM INSERTED) BEGIN INSERT INTO Runtime (SourceID, SourceTable) SELECT ID, 'CustomInputAdapter' FROM INSERTED END -- If a record has been deleted IF EXISTS(SELECT * FROM DELETED) BEGIN DELETE FROM Runtime WHERE SourceID IN (SELECT ID FROM DELETED) AND SourceTable = 'CustomInputAdapter' END END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[OutputStream]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [Acronym] [varchar](200) NOT NULL, [Name] [varchar](200) NULL, [Type] [int] NOT NULL CONSTRAINT [DF_OutputStream_Type] DEFAULT ((0)), [ConnectionString] [varchar](max) NULL, [DataChannel] [varchar](max) NULL, [CommandChannel] [varchar](max) NULL, [IDCode] [int] NOT NULL CONSTRAINT [DF_OutputStream_IDCode] DEFAULT ((0)), [AutoPublishConfigFrame] [bit] NOT NULL CONSTRAINT [DF_OutputStream_AutoPublishConfigFrame] DEFAULT ((0)), [AutoStartDataChannel] [bit] NOT NULL CONSTRAINT [DF_OutputStream_AutoStartDataChannel] DEFAULT ((1)), [NominalFrequency] [int] NOT NULL CONSTRAINT [DF_OutputStream_NominalFrequency] DEFAULT ((60)), [FramesPerSecond] [int] NOT NULL CONSTRAINT [DF_OutputStream_FramesPerSecond] DEFAULT ((30)), [LagTime] [float] NOT NULL CONSTRAINT [DF_OutputStream_LagTime] DEFAULT ((3.0)), [LeadTime] [float] NOT NULL CONSTRAINT [DF_OutputStream_LeadTime] DEFAULT ((1.0)), [UseLocalClockAsRealTime] [bit] NOT NULL CONSTRAINT [DF_OutputStream_UseLocalClockAsRealTime] DEFAULT ((0)), [AllowSortsByArrival] [bit] NOT NULL CONSTRAINT [DF_OutputStream_AllowSortsByArrival] DEFAULT ((1)), [IgnoreBadTimeStamps] [bit] NOT NULL CONSTRAINT [DF_OutputStream_IgnoreBadTimeStamps] DEFAULT ((0)), [TimeResolution] [int] NOT NULL CONSTRAINT [DF_OutputStream_TimeResolution] DEFAULT ((330000)), [AllowPreemptivePublishing] [bit] NOT NULL CONSTRAINT [DF_OutputStream_AllowPreemptivePublishing] DEFAULT ((1)), [PerformTimeReasonabilityCheck] [bit] NOT NULL CONSTRAINT [DF_OutputStream_PerformTimestampReasonabilityCheck] DEFAULT ((1)), [DownsamplingMethod] [varchar](15) NOT NULL CONSTRAINT [DF_OutputStream_DownsamplingMethod] DEFAULT (N'LastReceived'), [DataFormat] [varchar](15) NOT NULL CONSTRAINT [DF_OutputStream_DataFormat] DEFAULT (N'FloatingPoint'), [CoordinateFormat] [varchar](15) NOT NULL CONSTRAINT [DF_OutputStream_CoordinateFormat] DEFAULT (N'Polar'), [CurrentScalingValue] [int] NOT NULL CONSTRAINT [DF_OutputStream_CurrentScalingValue] DEFAULT ((2423)), [VoltageScalingValue] [int] NOT NULL CONSTRAINT [DF_OutputStream_VoltageScalingValue] DEFAULT ((2725785)), [AnalogScalingValue] [int] NOT NULL CONSTRAINT [DF_OutputStream_AnalogScalingValue] DEFAULT ((1373291)), [DigitalMaskValue] [int] NOT NULL CONSTRAINT [DF_OutputStream_DigitMaskValue] DEFAULT ((-65536)), [LoadOrder] [int] NOT NULL CONSTRAINT [DF_OutputStream_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_OutputStream_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStream_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStream_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_OutputStream_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_OutputStream_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_OutputStream] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO CREATE UNIQUE NONCLUSTERED INDEX [IX_OutputStream_Acronym] ON [dbo].[OutputStream] ( [NodeID] ASC, [Acronym] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TRIGGER [dbo].[OutputStream_RuntimeSync] ON [dbo].[OutputStream] AFTER INSERT, DELETE AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- If a new record has been added IF EXISTS(SELECT * FROM INSERTED) BEGIN INSERT INTO Runtime (SourceID, SourceTable) SELECT ID, 'OutputStream' FROM INSERTED END -- If a record has been deleted IF EXISTS(SELECT * FROM DELETED) BEGIN DELETE FROM Runtime WHERE SourceID IN (SELECT ID FROM DELETED) AND SourceTable = 'OutputStream' END END GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[Alarm]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [TagName] [varchar](200) NOT NULL, [SignalID] [uniqueidentifier] NOT NULL, [AssociatedMeasurementID] [uniqueidentifier] NULL, [Description] [varchar](max) NULL, [Severity] [int] NOT NULL, [Operation] [int] NOT NULL, [SetPoint] [float] NULL, [Tolerance] [float] NULL, [Delay] [float] NULL, [Hysteresis] [float] NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_Alarm_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_Alarm_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Alarm_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Alarm_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Alarm_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Alarm_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Alarm] PRIMARY KEY NONCLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO CREATE UNIQUE NONCLUSTERED INDEX [IX_Alarm_TagName] ON [dbo].[Alarm] ( [TagName] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[CustomOutputAdapter]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [AdapterName] [varchar](200) NOT NULL, [AssemblyName] [varchar](max) NOT NULL, [TypeName] [varchar](max) NOT NULL, [ConnectionString] [varchar](max) NULL, [LoadOrder] [int] NOT NULL CONSTRAINT [DF_CustomOutputAdapter_LoadOrder] DEFAULT ((0)), [Enabled] [bit] NOT NULL CONSTRAINT [DF_CustomOutputAdapter_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_CustomOutputAdapter_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CustomOutputAdapter_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_CustomOutputAdapter_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_CustomOutputAdapter_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_CustomOutputAdapter] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TRIGGER [dbo].[CustomOutputAdapter_RuntimeSync] ON [dbo].[CustomOutputAdapter] AFTER INSERT, DELETE AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from -- interfering with SELECT statements. SET NOCOUNT ON; -- If a new record has been added IF EXISTS(SELECT * FROM INSERTED) BEGIN INSERT INTO Runtime (SourceID, SourceTable) SELECT ID, 'CustomOutputAdapter' FROM INSERTED END -- If a record has been deleted IF EXISTS(SELECT * FROM DELETED) BEGIN DELETE FROM Runtime WHERE SourceID IN (SELECT ID FROM DELETED) AND SourceTable = 'CustomOutputAdapter' END END GO -- Application Security Related Tables and Views SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[UserAccount]( [ID] [uniqueidentifier] NOT NULL CONSTRAINT [DF_UserAccount_ID] DEFAULT (newid()), [Name] [varchar](200) NOT NULL, [Password] [varchar](200) NULL, [FirstName] [varchar](200) NULL, [LastName] [varchar](200) NULL, [DefaultNodeID] [uniqueidentifier] NOT NULL, [Phone] [varchar](200) NULL, [Email] [varchar](200) NULL, [LockedOut] [bit] NOT NULL CONSTRAINT [DF_UserAccount_LockedOut] DEFAULT ((0)), [UseADAuthentication] [bit] NOT NULL CONSTRAINT [DF_UserAccount_UseADAuthentication] DEFAULT ((1)), [ChangePasswordOn] [datetime] NULL CONSTRAINT [DF_UserAccount_ChangePasswordOn] DEFAULT (dateadd(day,(90),getutcdate())), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_UserAccount_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](50) NOT NULL CONSTRAINT [DF_UserAccount_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_UserAccount_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](50) NOT NULL CONSTRAINT [DF_UserAccount_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_UserAccount] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO ALTER TABLE [dbo].[UserAccount] WITH CHECK ADD CONSTRAINT [FK_UserAccount_Node] FOREIGN KEY([DefaultNodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[UserAccount] CHECK CONSTRAINT [FK_UserAccount_Node] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[ApplicationRole]( [ID] [uniqueidentifier] NOT NULL CONSTRAINT [DF_ApplicationRole_ID] DEFAULT (newid()), [Name] [varchar](200) NOT NULL, [Description] [varchar](max) NULL, [NodeID] [uniqueidentifier] NOT NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_ApplicationRole_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_ApplicationRole_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_ApplicationRole_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_ApplicationRole_UpdatedBy] DEFAULT (getutcdate()), CONSTRAINT [PK_ApplicationRole] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO ALTER TABLE [dbo].[ApplicationRole] WITH CHECK ADD CONSTRAINT [FK_ApplicationRole_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[ApplicationRole] CHECK CONSTRAINT [FK_ApplicationRole_Node] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[SecurityGroup]( [ID] [uniqueidentifier] NOT NULL CONSTRAINT [DF_SecurityGroup_ID] DEFAULT (newid()), [Name] [varchar](200) NOT NULL, [Description] [varchar](max) NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_SecurityGroup_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_SecurityGroup_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_SecurityGroup_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_SecurityGroup_UpdatedBy] DEFAULT (getutcdate()), CONSTRAINT [PK_SecurityGroup] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[SecurityGroupUserAccount]( [SecurityGroupID] [uniqueidentifier] NOT NULL, [UserAccountID] [uniqueidentifier] NOT NULL ) ON [PRIMARY] GO ALTER TABLE [dbo].[SecurityGroupUserAccount] WITH CHECK ADD CONSTRAINT [FK_SecurityGroupUserAccount_SecurityGroup] FOREIGN KEY([SecurityGroupID]) REFERENCES [dbo].[SecurityGroup] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[SecurityGroupUserAccount] CHECK CONSTRAINT [FK_SecurityGroupUserAccount_SecurityGroup] GO ALTER TABLE [dbo].[SecurityGroupUserAccount] WITH CHECK ADD CONSTRAINT [FK_SecurityGroupUserAccount_UserAccount] FOREIGN KEY([UserAccountID]) REFERENCES [dbo].[UserAccount] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[SecurityGroupUserAccount] CHECK CONSTRAINT [FK_SecurityGroupUserAccount_UserAccount] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[ApplicationRoleUserAccount]( [ApplicationRoleID] [uniqueidentifier] NOT NULL, [UserAccountID] [uniqueidentifier] NOT NULL ) ON [PRIMARY] GO ALTER TABLE [dbo].[ApplicationRoleUserAccount] WITH CHECK ADD CONSTRAINT [FK_ApplicationRoleUserAccount_ApplicationRole] FOREIGN KEY([ApplicationRoleID]) REFERENCES [dbo].[ApplicationRole] ([ID]) GO ALTER TABLE [dbo].[ApplicationRoleUserAccount] CHECK CONSTRAINT [FK_ApplicationRoleUserAccount_ApplicationRole] GO ALTER TABLE [dbo].[ApplicationRoleUserAccount] WITH CHECK ADD CONSTRAINT [FK_ApplicationRoleUserAccount_UserAccount] FOREIGN KEY([UserAccountID]) REFERENCES [dbo].[UserAccount] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[ApplicationRoleUserAccount] CHECK CONSTRAINT [FK_ApplicationRoleUserAccount_UserAccount] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[ApplicationRoleSecurityGroup]( [ApplicationRoleID] [uniqueidentifier] NOT NULL, [SecurityGroupID] [uniqueidentifier] NOT NULL ) ON [PRIMARY] GO ALTER TABLE [dbo].[ApplicationRoleSecurityGroup] WITH CHECK ADD CONSTRAINT [FK_ApplicationRoleSecurityGroup_SecurityGroup] FOREIGN KEY([SecurityGroupID]) REFERENCES [dbo].[SecurityGroup] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[ApplicationRoleSecurityGroup] CHECK CONSTRAINT [FK_ApplicationRoleSecurityGroup_SecurityGroup] GO ALTER TABLE [dbo].[ApplicationRoleSecurityGroup] WITH CHECK ADD CONSTRAINT [FK_ApplicationRoleSecurityGroup_ApplicationRole] FOREIGN KEY([ApplicationRoleID]) REFERENCES [dbo].[ApplicationRole] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[ApplicationRoleSecurityGroup] CHECK CONSTRAINT [FK_ApplicationRoleSecurityGroup_ApplicationRole] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[AccessLog]( [ID] [int] IDENTITY(1,1) NOT NULL, [UserName] [varchar](200) NOT NULL, [AccessGranted] [bit] NOT NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_AccessLog_Timestamp] DEFAULT (getutcdate()), CONSTRAINT [PK_AccessLog] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[Subscriber]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [uniqueidentifier] NOT NULL CONSTRAINT [DF_Subscriber_ID] DEFAULT (newid()), [Acronym] [varchar](200) NOT NULL, [Name] [varchar](200) NULL, [SharedSecret] [varchar](200) NOT NULL, [AuthKey] [varchar](max) NOT NULL, [ValidIPAddresses] [varchar](max) NOT NULL, [Enabled] [bit] NOT NULL CONSTRAINT [DF_Subscriber_Enabled] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_Subscriber_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Subscriber_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_Subscriber_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_Subscriber_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_Subscriber] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO ALTER TABLE [dbo].[Subscriber] WITH CHECK ADD CONSTRAINT [FK_Subscriber_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[Subscriber] CHECK CONSTRAINT [FK_Subscriber_Node] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[MeasurementGroup]( [NodeID] [uniqueidentifier] NOT NULL, [ID] [int] IDENTITY(1,1) NOT NULL, [Name] [varchar](200) NOT NULL, [Description] [varchar](max) NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_MeasurementGroup_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_MeasurementGroup_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_MeasurementGroup_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_MeasurementGroup_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_MeasurementGroup] PRIMARY KEY CLUSTERED ( [ID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO ALTER TABLE [dbo].[MeasurementGroup] WITH CHECK ADD CONSTRAINT [FK_MeasurementGroup_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[MeasurementGroup] CHECK CONSTRAINT [FK_MeasurementGroup_Node] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[MeasurementGroupMeasurement]( [NodeID] [uniqueidentifier] NOT NULL, [MeasurementGroupID] [int] NOT NULL, [SignalID] [uniqueidentifier] NOT NULL, [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_MeasurementGroupMeasurement_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_MeasurementGroupMeasurement_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_MeasurementGroupMeasurement_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_MeasurementGroupMeasurement_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_MeasurementGroupMeasurement] PRIMARY KEY CLUSTERED ( [NodeID] ASC, [MeasurementGroupID] ASC, [SignalID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO ALTER TABLE [dbo].[MeasurementGroupMeasurement] WITH CHECK ADD CONSTRAINT [FK_MeasurementGroupMeasurement_Measurement] FOREIGN KEY([SignalID]) REFERENCES [dbo].[Measurement] ([SignalID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[MeasurementGroupMeasurement] CHECK CONSTRAINT [FK_MeasurementGroupMeasurement_Measurement] GO ALTER TABLE [dbo].[MeasurementGroupMeasurement] WITH CHECK ADD CONSTRAINT [FK_MeasurementGroupMeasurement_MeasurementGroup] FOREIGN KEY([MeasurementGroupID]) REFERENCES [dbo].[MeasurementGroup] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[MeasurementGroupMeasurement] CHECK CONSTRAINT [FK_MeasurementGroupMeasurement_MeasurementGroup] GO ALTER TABLE [dbo].[MeasurementGroupMeasurement] WITH CHECK ADD CONSTRAINT [FK_MeasurementGroupMeasurement_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[MeasurementGroupMeasurement] CHECK CONSTRAINT [FK_MeasurementGroupMeasurement_Node] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[SubscriberMeasurement]( [NodeID] [uniqueidentifier] NOT NULL, [SubscriberID] [uniqueidentifier] NOT NULL, [SignalID] [uniqueidentifier] NOT NULL, [Allowed] [bit] NOT NULL CONSTRAINT [DF_SubscriberMeasurement_Allowed] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_SubscriberMeasurement_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_SubscriberMeasurement_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_SubscriberMeasurement_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_SubscriberMeasurement_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_SubscriberMeasurement] PRIMARY KEY CLUSTERED ( [NodeID] ASC, [SubscriberID] ASC, [SignalID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO ALTER TABLE [dbo].[SubscriberMeasurement] WITH CHECK ADD CONSTRAINT [FK_SubscriberMeasurement_Measurement] FOREIGN KEY([SignalID]) REFERENCES [dbo].[Measurement] ([SignalID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[SubscriberMeasurement] CHECK CONSTRAINT [FK_SubscriberMeasurement_Measurement] GO ALTER TABLE [dbo].[SubscriberMeasurement] WITH CHECK ADD CONSTRAINT [FK_SubscriberMeasurement_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[SubscriberMeasurement] CHECK CONSTRAINT [FK_SubscriberMeasurement_Node] GO ALTER TABLE [dbo].[SubscriberMeasurement] WITH CHECK ADD CONSTRAINT [FK_SubscriberMeasurement_Subscriber] FOREIGN KEY([SubscriberID]) REFERENCES [dbo].[Subscriber] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[SubscriberMeasurement] CHECK CONSTRAINT [FK_SubscriberMeasurement_Subscriber] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO SET ANSI_PADDING ON GO CREATE TABLE [dbo].[SubscriberMeasurementGroup]( [NodeID] [uniqueidentifier] NOT NULL, [SubscriberID] [uniqueidentifier] NOT NULL, [MeasurementGroupID] [int] NOT NULL, [Allowed] [bit] NOT NULL CONSTRAINT [DF_SubscriberMeasurementGroup_Allowed] DEFAULT ((0)), [CreatedOn] [datetime] NOT NULL CONSTRAINT [DF_SubscriberMeasurementGroup_CreatedOn] DEFAULT (getutcdate()), [CreatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_SubscriberMeasurementGroup_CreatedBy] DEFAULT (suser_name()), [UpdatedOn] [datetime] NOT NULL CONSTRAINT [DF_SubscriberMeasurementGroup_UpdatedOn] DEFAULT (getutcdate()), [UpdatedBy] [varchar](200) NOT NULL CONSTRAINT [DF_SubscriberMeasurementGroup_UpdatedBy] DEFAULT (suser_name()), CONSTRAINT [PK_SubscriberMeasurementGroup] PRIMARY KEY CLUSTERED ( [NodeID] ASC, [SubscriberID] ASC, [MeasurementGroupID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] GO SET ANSI_PADDING OFF GO ALTER TABLE [dbo].[SubscriberMeasurementGroup] WITH CHECK ADD CONSTRAINT [FK_SubscriberMeasurementGroup_MeasurementGroup] FOREIGN KEY([MeasurementGroupID]) REFERENCES [dbo].[MeasurementGroup] ([ID]) GO ALTER TABLE [dbo].[SubscriberMeasurementGroup] CHECK CONSTRAINT [FK_SubscriberMeasurementGroup_MeasurementGroup] GO ALTER TABLE [dbo].[SubscriberMeasurementGroup] WITH CHECK ADD CONSTRAINT [FK_SubscriberMeasurementGroup_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[SubscriberMeasurementGroup] CHECK CONSTRAINT [FK_SubscriberMeasurementGroup_Node] GO ALTER TABLE [dbo].[SubscriberMeasurementGroup] WITH CHECK ADD CONSTRAINT [FK_SubscriberMeasurementGroup_Subscriber] FOREIGN KEY([SubscriberID]) REFERENCES [dbo].[Subscriber] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[SubscriberMeasurementGroup] CHECK CONSTRAINT [FK_SubscriberMeasurementGroup_Subscriber] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[NodeInfo] AS SELECT dbo.Node.ID AS NodeID, dbo.Node.Name, dbo.Company.Name AS CompanyName, dbo.Node.Longitude, dbo.Node.Latitude, dbo.Node.Description, dbo.Node.ImagePath, dbo.Node.Settings, dbo.Node.MenuType, dbo.Node.MenuData, dbo.Node.Master, dbo.Node.Enabled FROM dbo.Node LEFT OUTER JOIN dbo.Company ON dbo.Node.CompanyID = dbo.Company.ID GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[SecurityGroupUserAccountDetail] AS SELECT dbo.SecurityGroupUserAccount.SecurityGroupID, dbo.SecurityGroupUserAccount.UserAccountID, UserAccount.Name AS UserName, UserAccount.FirstName, UserAccount.LastName, UserAccount.Email, dbo.SecurityGroup.Name AS SecurityGroupName, dbo.SecurityGroup.Description AS SecurityGroupDescription FROM dbo.SecurityGroupUserAccount INNER JOIN dbo.SecurityGroup ON dbo.SecurityGroupUserAccount.SecurityGroupID = dbo.SecurityGroup.ID INNER JOIN UserAccount ON dbo.SecurityGroupUserAccount.UserAccountID = UserAccount.ID GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[AppRoleSecurityGroupDetail] AS SELECT ApplicationRoleSecurityGroup.ApplicationRoleID, ApplicationRoleSecurityGroup.SecurityGroupID, ApplicationRole.Name AS ApplicationRoleName, ApplicationRole.Description AS ApplicationRoleDescription, SecurityGroup.Name AS SecurityGroupName, SecurityGroup.Description AS SecurityGroupDescription FROM ApplicationRoleSecurityGroup, ApplicationRole, SecurityGroup WHERE ApplicationRoleSecurityGroup.ApplicationRoleID = ApplicationRole.ID AND ApplicationRoleSecurityGroup.SecurityGroupID = SecurityGroup.ID GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[AppRoleUserAccountDetail] AS SELECT dbo.ApplicationRoleUserAccount.ApplicationRoleID, dbo.ApplicationRoleUserAccount.UserAccountID, UserAccount.Name AS UserName, UserAccount.FirstName, UserAccount.LastName, UserAccount.Email, dbo.ApplicationRole.Name AS ApplicationRoleName, dbo.ApplicationRole.Description AS ApplicationRoleDescription FROM dbo.ApplicationRoleUserAccount INNER JOIN dbo.ApplicationRole ON dbo.ApplicationRoleUserAccount.ApplicationRoleID = dbo.ApplicationRole.ID INNER JOIN UserAccount ON dbo.ApplicationRoleUserAccount.UserAccountID = UserAccount.ID GO -- End of Application Security related tables and views definitions. SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeOutputStreamMeasurement] AS SELECT TOP (100) PERCENT dbo.OutputStreamMeasurement.NodeID, dbo.Runtime.ID AS AdapterID, dbo.Historian.Acronym AS Historian, dbo.OutputStreamMeasurement.PointID, dbo.OutputStreamMeasurement.SignalReference FROM dbo.OutputStreamMeasurement LEFT OUTER JOIN dbo.Historian ON dbo.OutputStreamMeasurement.HistorianID = dbo.Historian.ID LEFT OUTER JOIN dbo.Runtime ON dbo.OutputStreamMeasurement.AdapterID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'OutputStream' ORDER BY dbo.OutputStreamMeasurement.HistorianID, dbo.OutputStreamMeasurement.PointID GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeHistorian] AS SELECT TOP (100) PERCENT dbo.Historian.NodeID, dbo.Runtime.ID, dbo.Historian.Acronym AS AdapterName, COALESCE (NULLIF(LTRIM(RTRIM(dbo.Historian.AssemblyName)), ''), N'HistorianAdapters.dll') AS AssemblyName, COALESCE (NULLIF(LTRIM(RTRIM(dbo.Historian.TypeName)), ''), CASE dbo.Historian.IsLocal WHEN 1 THEN N'HistorianAdapters.LocalOutputAdapter' ELSE N'HistorianAdapters.RemoteOutputAdapter' END) AS TypeName, CASE WHEN Historian.ConnectionString IS NULL THEN N'' ELSE Historian.ConnectionString + N'; ' END + N'instanceName=' + dbo.Historian.Acronym + N'; sourceids=' + dbo.Historian.Acronym + N'; measurementReportingInterval=' + CONVERT(NVARCHAR(10), dbo.Historian.MeasurementReportingInterval) AS ConnectionString FROM dbo.Historian LEFT OUTER JOIN dbo.Runtime ON dbo.Historian.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'Historian' WHERE (dbo.Historian.Enabled <> 0) ORDER BY dbo.Historian.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeDevice] AS SELECT TOP (100) PERCENT dbo.Device.NodeID, dbo.Runtime.ID, dbo.Device.Acronym AS AdapterName, dbo.Protocol.AssemblyName, dbo.Protocol.TypeName, CASE WHEN dbo.Device.ConnectionString IS NULL THEN N'' ELSE dbo.Device.ConnectionString END + N'; isConcentrator=' + CONVERT(NVARCHAR(10), dbo.Device.IsConcentrator) + N'; accessID=' + CONVERT(NVARCHAR(10), dbo.Device.AccessID) + CASE WHEN dbo.Device.TimeZone IS NULL THEN N'' ELSE N'; timeZone=' + dbo.Device.TimeZone END + N'; timeAdjustmentTicks=' + CONVERT(NVARCHAR(30), dbo.Device.TimeAdjustmentTicks) + CASE WHEN dbo.Protocol.Acronym IS NULL THEN N'' ELSE N'; phasorProtocol=' + dbo.Protocol.Acronym END + N'; dataLossInterval=' + CONVERT(NVARCHAR(10), dbo.Device.DataLossInterval) + N'; allowedParsingExceptions=' + CONVERT(NVARCHAR(10), dbo.Device.AllowedParsingExceptions) + N'; parsingExceptionWindow=' + CONVERT(NVARCHAR(10), dbo.Device.ParsingExceptionWindow) + N'; delayedConnectionInterval=' + CONVERT(NVARCHAR(10), dbo.Device.DelayedConnectionInterval) + N'; allowUseOfCachedConfiguration=' + CONVERT (NVARCHAR(10), dbo.Device.AllowUseOfCachedConfiguration) + N'; autoStartDataParsingSequence=' + CONVERT(NVARCHAR(10), dbo.Device.AutoStartDataParsingSequence) + N'; skipDisableRealTimeData=' + CONVERT(NVARCHAR(10), dbo.Device.SkipDisableRealTimeData) + N'; measurementReportingInterval=' + CONVERT(NVARCHAR(10), dbo.Device.MeasurementReportingInterval) + N'; connectOnDemand=' + CONVERT(NVARCHAR(10), dbo.Device.ConnectOnDemand) AS ConnectionString FROM dbo.Device LEFT OUTER JOIN dbo.Protocol ON dbo.Device.ProtocolID = dbo.Protocol.ID LEFT OUTER JOIN dbo.Runtime ON dbo.Device.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'Device' WHERE (dbo.Device.Enabled <> 0 AND Device.ParentID IS NULL) ORDER BY dbo.Device.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeCustomOutputAdapter] AS SELECT TOP (100) PERCENT dbo.CustomOutputAdapter.NodeID, dbo.Runtime.ID, dbo.CustomOutputAdapter.AdapterName, LTRIM(RTRIM(dbo.CustomOutputAdapter.AssemblyName)) AS AssemblyName, LTRIM(RTRIM(dbo.CustomOutputAdapter.TypeName)) AS TypeName, dbo.CustomOutputAdapter.ConnectionString FROM dbo.CustomOutputAdapter LEFT OUTER JOIN dbo.Runtime ON dbo.CustomOutputAdapter.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'CustomOutputAdapter' WHERE (dbo.CustomOutputAdapter.Enabled <> 0) ORDER BY dbo.CustomOutputAdapter.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeInputStreamDevice] AS SELECT TOP (100) PERCENT dbo.Device.NodeID, Runtime_P.ID AS ParentID, dbo.Runtime.ID, dbo.Device.Acronym, dbo.Device.Name, dbo.Device.AccessID FROM dbo.Device LEFT OUTER JOIN dbo.Runtime ON dbo.Device.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'Device' LEFT OUTER JOIN dbo.Runtime AS Runtime_P ON dbo.Device.ParentID = Runtime_P.SourceID AND Runtime_P.SourceTable = N'Device' WHERE (dbo.Device.IsConcentrator = 0) AND (dbo.Device.Enabled <> 0) AND (dbo.Device.ParentID IS NOT NULL) ORDER BY dbo.Device.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeCustomInputAdapter] AS SELECT TOP (100) PERCENT dbo.CustomInputAdapter.NodeID, dbo.Runtime.ID, dbo.CustomInputAdapter.AdapterName, LTRIM(RTRIM(dbo.CustomInputAdapter.AssemblyName)) AS AssemblyName, LTRIM(RTRIM(dbo.CustomInputAdapter.TypeName)) AS TypeName, dbo.CustomInputAdapter.ConnectionString FROM dbo.CustomInputAdapter LEFT OUTER JOIN dbo.Runtime ON dbo.CustomInputAdapter.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'CustomInputAdapter' WHERE (dbo.CustomInputAdapter.Enabled <> 0) ORDER BY dbo.CustomInputAdapter.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeOutputStreamDevice] AS SELECT TOP (100) PERCENT dbo.OutputStreamDevice.NodeID, dbo.Runtime.ID AS ParentID, dbo.OutputStreamDevice.ID, dbo.OutputStreamDevice.IDCode, dbo.OutputStreamDevice.Acronym, dbo.OutputStreamDevice.BpaAcronym, dbo.OutputStreamDevice.Name, NULLIF(dbo.OutputStreamDevice.PhasorDataFormat, '') AS PhasorDataFormat, NULLIF(dbo.OutputStreamDevice.FrequencyDataFormat, '') AS FrequencyDataFormat, NULLIF(dbo.OutputStreamDevice.AnalogDataFormat, '') AS AnalogDataFormat, NULLIF(dbo.OutputStreamDevice.CoordinateFormat, '') AS CoordinateFormat, dbo.OutputStreamDevice.LoadOrder FROM dbo.OutputStreamDevice LEFT OUTER JOIN dbo.Runtime ON dbo.OutputStreamDevice.AdapterID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'OutputStream' WHERE (dbo.OutputStreamDevice.Enabled <> 0) ORDER BY dbo.OutputStreamDevice.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeOutputStream] AS SELECT TOP (100) PERCENT dbo.OutputStream.NodeID, dbo.Runtime.ID, dbo.OutputStream.Acronym AS AdapterName, N'TVA.PhasorProtocols.dll' AS AssemblyName, CASE Type WHEN 1 THEN N'TVA.PhasorProtocols.BpaPdcStream.Concentrator' ELSE N'TVA.PhasorProtocols.IeeeC37_118.Concentrator' END AS TypeName, CASE WHEN dbo.OutputStream.ConnectionString IS NULL THEN N'' ELSE dbo.OutputStream.ConnectionString + N'; ' END + CASE WHEN dbo.OutputStream.DataChannel IS NULL THEN N'' ELSE N'dataChannel={' + dbo.OutputStream.DataChannel + N'}' END + CASE WHEN dbo.OutputStream.CommandChannel IS NULL THEN N'' ELSE N'; commandChannel={' + dbo.OutputStream.CommandChannel + N'}' END + N'; idCode=' + CONVERT(NVARCHAR(10), dbo.OutputStream.IDCode) + N'; autoPublishConfigFrame=' + CONVERT(NVARCHAR(10), dbo.OutputStream.AutoPublishConfigFrame) + N'; autoStartDataChannel=' + CONVERT(NVARCHAR(10), dbo.OutputStream.AutoStartDataChannel) + N'; nominalFrequency=' + CONVERT(NVARCHAR(10), dbo.OutputStream.NominalFrequency) + N'; lagTime=' + CONVERT(NVARCHAR(10), dbo.OutputStream.LagTime) + N'; leadTime=' + CONVERT(NVARCHAR(10), dbo.OutputStream.LeadTime) + N'; framesPerSecond=' + CONVERT(NVARCHAR(10), dbo.OutputStream.FramesPerSecond) + N'; useLocalClockAsRealTime=' + CONVERT(NVARCHAR(10), dbo.OutputStream.UseLocalClockAsRealTime) + N'; allowSortsByArrival=' + CONVERT(NVARCHAR(10), dbo.OutputStream.AllowSortsByArrival) + N'; ignoreBadTimestamps=' + CONVERT(NVARCHAR(10), dbo.OutputStream.IgnoreBadTimestamps) + N'; timeResolution=' + CONVERT(NVARCHAR(10), dbo.OutputStream.TimeResolution) + N'; allowPreemptivePublishing=' + CONVERT(NVARCHAR(10), dbo.OutputStream.AllowPreemptivePublishing) + N'; performTimestampReasonabilityCheck=' + CONVERT(NVARCHAR(10), dbo.OutputStream.PerformTimeReasonabilityCheck) + N'; downsamplingMethod=' + dbo.OutputStream.DownsamplingMethod + N'; dataFormat=' + dbo.OutputStream.DataFormat + N'; coordinateFormat=' + dbo.OutputStream.CoordinateFormat + N'; currentScalingValue=' + CONVERT(NVARCHAR(10), dbo.OutputStream.CurrentScalingValue) + N'; voltageScalingValue=' + CONVERT(NVARCHAR(10), dbo.OutputStream.VoltageScalingValue) + N'; analogScalingValue=' + CONVERT(NVARCHAR(10), dbo.OutputStream.AnalogScalingValue) + N'; digitalMaskValue=' + CONVERT(NVARCHAR(10), dbo.OutputStream.DigitalMaskValue) AS ConnectionString FROM dbo.OutputStream LEFT OUTER JOIN dbo.Runtime ON dbo.OutputStream.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'OutputStream' WHERE (dbo.OutputStream.Enabled <> 0) ORDER BY dbo.OutputStream.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeCustomActionAdapter] AS SELECT TOP (100) PERCENT dbo.CustomActionAdapter.NodeID, dbo.Runtime.ID, dbo.CustomActionAdapter.AdapterName, LTRIM(RTRIM(dbo.CustomActionAdapter.AssemblyName)) AS AssemblyName, LTRIM(RTRIM(dbo.CustomActionAdapter.TypeName)) AS TypeName, dbo.CustomActionAdapter.ConnectionString FROM dbo.CustomActionAdapter LEFT OUTER JOIN dbo.Runtime ON dbo.CustomActionAdapter.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'CustomActionAdapter' WHERE (dbo.CustomActionAdapter.Enabled <> 0) ORDER BY dbo.CustomActionAdapter.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[MeasurementDetail] AS SELECT dbo.Device.CompanyID, dbo.Company.Acronym AS CompanyAcronym, dbo.Company.Name AS CompanyName, dbo.Measurement.SignalID, dbo.Measurement.HistorianID, dbo.Historian.Acronym AS HistorianAcronym, dbo.Historian.ConnectionString AS HistorianConnectionString, dbo.Measurement.PointID, dbo.Measurement.PointTag, dbo.Measurement.AlternateTag, dbo.Measurement.DeviceID, COALESCE (dbo.Device.NodeID, dbo.Historian.NodeID) AS NodeID, dbo.Device.Acronym AS DeviceAcronym, dbo.Device.Name AS DeviceName, COALESCE(dbo.Device.FramesPerSecond, 30) AS FramesPerSecond, dbo.Device.Enabled AS DeviceEnabled, dbo.Device.ContactList, dbo.Device.VendorDeviceID, dbo.VendorDevice.Name AS VendorDeviceName, dbo.VendorDevice.Description AS VendorDeviceDescription, dbo.Device.ProtocolID, dbo.Protocol.Acronym AS ProtocolAcronym, dbo.Protocol.Name AS ProtocolName, dbo.Measurement.SignalTypeID, dbo.Measurement.PhasorSourceIndex, dbo.Phasor.Label AS PhasorLabel, dbo.Phasor.Type AS PhasorType, dbo.Phasor.Phase, dbo.Measurement.SignalReference, dbo.Measurement.Adder, dbo.Measurement.Multiplier, dbo.Measurement.Description, dbo.Measurement.Subscribed, dbo.Measurement.Internal, dbo.Measurement.Enabled, COALESCE (dbo.SignalType.EngineeringUnits, N'') AS EngineeringUnits, dbo.SignalType.Source, dbo.SignalType.Acronym AS SignalAcronym, dbo.SignalType.Name AS SignalName, dbo.SignalType.Suffix AS SignalTypeSuffix, dbo.Device.Longitude, dbo.Device.Latitude, COALESCE(Historian.Acronym, Device.Acronym, '__') + ':' + CONVERT(NVARCHAR(10), Measurement.PointID) AS ID FROM dbo.Company RIGHT OUTER JOIN dbo.Device ON dbo.Company.ID = dbo.Device.CompanyID RIGHT OUTER JOIN dbo.Measurement LEFT OUTER JOIN dbo.SignalType ON dbo.Measurement.SignalTypeID = dbo.SignalType.ID ON dbo.Device.ID = dbo.Measurement.DeviceID LEFT OUTER JOIN dbo.Phasor ON dbo.Measurement.DeviceID = dbo.Phasor.DeviceID AND dbo.Measurement.PhasorSourceIndex = dbo.Phasor.SourceIndex LEFT OUTER JOIN dbo.VendorDevice ON dbo.Device.VendorDeviceID = dbo.VendorDevice.ID LEFT OUTER JOIN dbo.Protocol ON dbo.Device.ProtocolID = dbo.Protocol.ID LEFT OUTER JOIN dbo.Historian ON dbo.Measurement.HistorianID = dbo.Historian.ID GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeCalculatedMeasurement] AS SELECT TOP (100) PERCENT dbo.CalculatedMeasurement.NodeID, dbo.Runtime.ID, dbo.CalculatedMeasurement.Acronym AS AdapterName, LTRIM(RTRIM(dbo.CalculatedMeasurement.AssemblyName)) AS AssemblyName, LTRIM(RTRIM(dbo.CalculatedMeasurement.TypeName)) AS TypeName, CASE WHEN dbo.CalculatedMeasurement.ConnectionString IS NULL THEN N'' ELSE dbo.CalculatedMeasurement.ConnectionString + N'; ' END + CASE WHEN ConfigSection IS NULL THEN N'' ELSE N'configurationSection=' + ConfigSection + N'; ' END + N'minimumMeasurementsToUse=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.MinimumMeasurementsToUse) + N'; framesPerSecond=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.FramesPerSecond) + N'; lagTime=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.LagTime) + N'; leadTime=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.LeadTime) + CASE WHEN InputMeasurements IS NULL THEN N'' ELSE N'; inputMeasurementKeys={' + InputMeasurements + '}' END + CASE WHEN OutputMeasurements IS NULL THEN N'' ELSE N'; outputMeasurements={' + OutputMeasurements + '}' END + N'; ignoreBadTimestamps=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.IgnoreBadTimeStamps) + N'; timeResolution=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.TimeResolution) + N'; allowPreemptivePublishing=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.AllowPreemptivePublishing) + N'; performTimestampReasonabilityCheck=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.PerformTimeReasonabilityCheck) + N'; downsamplingMethod=' + dbo.CalculatedMeasurement.DownsamplingMethod + N'; useLocalClockAsRealTime=' + CONVERT(NVARCHAR(10), dbo.CalculatedMeasurement.UseLocalClockAsRealTime) AS ConnectionString FROM dbo.CalculatedMeasurement LEFT OUTER JOIN dbo.Runtime ON dbo.CalculatedMeasurement.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'CalculatedMeasurement' WHERE (dbo.CalculatedMeasurement.Enabled <> 0) ORDER BY dbo.CalculatedMeasurement.LoadOrder GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[ActiveMeasurement] AS SELECT dbo.Node.ID AS NodeID, COALESCE(dbo.Device.NodeID, dbo.Historian.NodeID) AS SourceNodeID, COALESCE(dbo.Historian.Acronym, dbo.Device.Acronym, '__') + ':' + CONVERT(NVARCHAR(10), dbo.Measurement.PointID) AS ID, dbo.Measurement.SignalID, dbo.Measurement.PointTag, dbo.Measurement.AlternateTag, dbo.Measurement.SignalReference, dbo.Measurement.Internal, dbo.Measurement.Subscribed, dbo.Device.Acronym AS Device, CASE WHEN dbo.Device.IsConcentrator = 0 AND dbo.Device.ParentID IS NOT NULL THEN RuntimeP.ID ELSE dbo.Runtime.ID END AS DeviceID, COALESCE(dbo.Device.FramesPerSecond, 30) AS FramesPerSecond, dbo.Protocol.Acronym AS Protocol, dbo.Protocol.Type AS ProtocolType, dbo.SignalType.Acronym AS SignalType, dbo.Phasor.ID AS PhasorID, dbo.Phasor.Type AS PhasorType, dbo.Phasor.Phase, dbo.Measurement.Adder, dbo.Measurement.Multiplier, dbo.Company.Acronym AS Company, dbo.Device.Longitude, dbo.Device.Latitude, dbo.Measurement.Description FROM dbo.Company RIGHT OUTER JOIN dbo.Device ON dbo.Company.ID = dbo.Device.CompanyID RIGHT OUTER JOIN dbo.Measurement LEFT OUTER JOIN dbo.SignalType ON dbo.Measurement.SignalTypeID = dbo.SignalType.ID ON dbo.Device.ID = dbo.Measurement.DeviceID LEFT OUTER JOIN dbo.Phasor ON dbo.Measurement.DeviceID = dbo.Phasor.DeviceID AND dbo.Measurement.PhasorSourceIndex = dbo.Phasor.SourceIndex LEFT OUTER JOIN dbo.Protocol ON dbo.Device.ProtocolID = dbo.Protocol.ID LEFT OUTER JOIN dbo.Historian ON dbo.Measurement.HistorianID = dbo.Historian.ID LEFT OUTER JOIN dbo.Runtime ON dbo.Device.ID = dbo.Runtime.SourceID AND dbo.Runtime.SourceTable = N'Device' LEFT OUTER JOIN dbo.Runtime AS RuntimeP ON RuntimeP.SourceID = dbo.Device.ParentID AND RuntimeP.SourceTable = N'Device' CROSS JOIN dbo.Node WHERE (dbo.Device.Enabled <> 0 OR dbo.Device.Enabled IS NULL) AND (dbo.Measurement.Enabled <> 0) UNION ALL SELECT NodeID, SourceNodeID, Source + ':' + CONVERT(NVARCHAR(10), PointID) AS ID, SignalID, PointTag, AlternateTag, SignalReference, 0 AS Internal, 1 AS Subscribed, NULL AS Device, NULL AS DeviceID, FramesPerSecond, ProtocolAcronym AS Protocol, ProtocolType, SignalTypeAcronym AS SignalType, PhasorID, PhasorType, Phase, Adder, Multiplier, CompanyAcronym AS Company, Longitude, Latitude, Description FROM dbo.ImportedMeasurement WHERE dbo.ImportedMeasurement.Enabled <> 0 GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[RuntimeStatistic] AS SELECT dbo.Node.ID AS NodeID, dbo.Statistic.ID AS ID, dbo.Statistic.Source, dbo.Statistic.SignalIndex, dbo.Statistic.Name, dbo.Statistic.Description, dbo.Statistic.AssemblyName, dbo.Statistic.TypeName, dbo.Statistic.MethodName, dbo.Statistic.Arguments, dbo.Statistic.IsConnectedState, dbo.Statistic.DataType, dbo.Statistic.DisplayFormat, dbo.Statistic.Enabled FROM dbo.Statistic, dbo.Node GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[IaonOutputAdapter] AS SELECT NodeID, ID, AdapterName, AssemblyName, TypeName, ConnectionString FROM dbo.RuntimeHistorian UNION SELECT NodeID, ID, AdapterName, AssemblyName, TypeName, ConnectionString FROM dbo.RuntimeCustomOutputAdapter GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[IaonInputAdapter] AS SELECT NodeID, ID, AdapterName, AssemblyName, TypeName, ConnectionString FROM dbo.RuntimeDevice UNION SELECT NodeID, ID, AdapterName, AssemblyName, TypeName, ConnectionString FROM dbo.RuntimeCustomInputAdapter GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE VIEW [dbo].[IaonActionAdapter] AS SELECT Node.ID AS NodeID, 0 AS ID, N'PHASOR!SERVICES' AS AdapterName, N'TVA.PhasorProtocols.dll' AS AssemblyName, N'TVA.PhasorProtocols.CommonPhasorServices' AS TypeName, N'' AS ConnectionString FROM dbo.Node UNION SELECT NodeID, ID, AdapterName, AssemblyName, TypeName, ConnectionString FROM dbo.RuntimeOutputStream UNION SELECT NodeID, ID, AdapterName, AssemblyName, TypeName, ConnectionString FROM dbo.RuntimeCalculatedMeasurement UNION SELECT NodeID, ID, AdapterName, AssemblyName, TypeName, ConnectionString FROM dbo.RuntimeCustomActionAdapter GO CREATE VIEW [dbo].[HistorianMetadata] AS SELECT HistorianID = PointID, DataType = CASE SignalAcronym WHEN 'DIGI' THEN 1 ELSE 0 END, [Name] = PointTag, Synonym1 = CONVERT(VARCHAR(40), SignalReference), Synonym2 = SignalAcronym, Synonym3 = AlternateTag, Description = CONVERT(VARCHAR(80), Description), HardwareInfo = VendorDeviceDescription, Remarks = '', PlantCode = HistorianAcronym, UnitNumber = 1, SystemName = DeviceAcronym, SourceID = ProtocolID, Enabled = Enabled, ScanRate = 1.0 / FramesPerSecond, CompressionMinTime = 0, CompressionMaxTime = 0, EngineeringUnits = EngineeringUnits, LowWarning = CASE SignalAcronym WHEN 'FREQ' THEN 59.95 WHEN 'VPHM' THEN 475000 WHEN 'IPHM' THEN 0 WHEN 'VPHA' THEN -181 WHEN 'IPHA' THEN -181 ELSE 0 END, HighWarning = CASE SignalAcronym WHEN 'FREQ' THEN 60.05 WHEN 'VPHM' THEN 525000 WHEN 'IPHM' THEN 3150 WHEN 'VPHA' THEN 181 WHEN 'IPHA' THEN 181 ELSE 0 END, LowAlarm = CASE SignalAcronym WHEN 'FREQ' THEN 59.90 WHEN 'VPHM' THEN 450000 WHEN 'IPHM' THEN 0 WHEN 'VPHA' THEN -181 WHEN 'IPHA' THEN -181 ELSE 0 END, HighAlarm = CASE SignalAcronym WHEN 'FREQ' THEN 60.10 WHEN 'VPHM' THEN 550000 WHEN 'IPHM' THEN 3300 WHEN 'VPHA' THEN 181 WHEN 'IPHA' THEN 181 ELSE 0 END, LowRange = CASE SignalAcronym WHEN 'FREQ' THEN 59.95 WHEN 'VPHM' THEN 475000 WHEN 'IPHM' THEN 0 WHEN 'VPHA' THEN -180 WHEN 'IPHA' THEN -180 ELSE 0 END, HighRange = CASE SignalAcronym WHEN 'FREQ' THEN 60.05 WHEN 'VPHM' THEN 525000 WHEN 'IPHM' THEN 3000 WHEN 'VPHA' THEN 180 WHEN 'IPHA' THEN 180 ELSE 0 END, CompressionLimit = 0.0, ExceptionLimit = 0.0, DisplayDigits = CASE SignalAcronym WHEN 'DIGI' THEN 0 ELSE 7 END, SetDescription = '', ClearDescription = '', AlarmState = 0, ChangeSecurity = 5, AccessSecurity = 0, StepCheck = 0, AlarmEnabled = 0, AlarmFlags = 0, AlarmDelay = 0, AlarmToFile = 0, AlarmByEmail = 0, AlarmByPager = 0, AlarmByPhone = 0, AlarmEmails = MeasurementDetail.ContactList, AlarmPagers = '', AlarmPhones = '' FROM [dbo].[MeasurementDetail] GO CREATE VIEW [dbo].[CalculatedMeasurementDetail] AS SELECT CM.NodeID, CM.ID, CM.Acronym, ISNULL(CM.Name, '') AS Name, CM.AssemblyName, CM.TypeName, ISNULL(CM.ConnectionString, '') AS ConnectionString, ISNULL(CM.ConfigSection, '') AS ConfigSection, ISNULL(CM.InputMeasurements, '') AS InputMeasurements, ISNULL(CM.OutputMeasurements, '') AS OutputMeasurements, CM.MinimumMeasurementsToUse, CM.FramesPerSecond, CM.LagTime, CM.LeadTime, CM.UseLocalClockAsRealTime, CM.AllowSortsByArrival, CM.LoadOrder, CM.Enabled, N.Name AS NodeName, CM.IgnoreBadTimeStamps, CM.TimeResolution, CM.AllowPreemptivePublishing, ISNULL(CM.DownsamplingMethod, '') AS DownsamplingMethod, CM.PerformTimeReasonabilityCheck FROM CalculatedMeasurement CM, Node N WHERE CM.NodeID = N.ID GO CREATE VIEW [dbo].[VendorDeviceDetail] AS SELECT VD.ID, VD.VendorID, VD.Name, ISNULL(VD.Description, '') AS Description, ISNULL(VD.URL, '') AS URL, V.Name AS VendorName, V.Acronym AS VendorAcronym FROM dbo.VendorDevice AS VD INNER JOIN dbo.Vendor AS V ON VD.VendorID = V.ID GO CREATE VIEW [dbo].[DeviceDetail] AS SELECT D.NodeID, D.ID, D.ParentID, D.UniqueID, D.Acronym, ISNULL(D.Name, '') AS Name, D.OriginalSource, D.IsConcentrator, D.CompanyID, D.HistorianID, D.AccessID, D.VendorDeviceID, D.ProtocolID, D.Longitude, D.Latitude, D.InterconnectionID, ISNULL(D.ConnectionString, '') AS ConnectionString, ISNULL(D.TimeZone, '') AS TimeZone, ISNULL(D.FramesPerSecond, 30) AS FramesPerSecond, D.TimeAdjustmentTicks, D.DataLossInterval, D.ConnectOnDemand, ISNULL(D.ContactList, '') AS ContactList, D.MeasuredLines, D.LoadOrder, D.Enabled, ISNULL(C.Name, '') AS CompanyName, ISNULL(C.Acronym, '') AS CompanyAcronym, ISNULL(C.MapAcronym, '') AS CompanyMapAcronym, ISNULL(H.Acronym, '') AS HistorianAcronym, ISNULL(VD.VendorAcronym, '') AS VendorAcronym, ISNULL(VD.Name, '') AS VendorDeviceName, ISNULL(P.Name, '') AS ProtocolName, P.Type AS ProtocolType, P.Category, ISNULL(I.Name, '') AS InterconnectionName, N.Name AS NodeName, ISNULL(PD.Acronym, '') AS ParentAcronym, D.CreatedOn, D.AllowedParsingExceptions, D.ParsingExceptionWindow, D.DelayedConnectionInterval, D.AllowUseOfCachedConfiguration, D.AutoStartDataParsingSequence, D.SkipDisableRealTimeData, D.MeasurementReportingInterval FROM dbo.Device AS D LEFT OUTER JOIN dbo.Company AS C ON C.ID = D.CompanyID LEFT OUTER JOIN dbo.Historian AS H ON H.ID = D.HistorianID LEFT OUTER JOIN dbo.VendorDeviceDetail AS VD ON VD.ID = D.VendorDeviceID LEFT OUTER JOIN dbo.Protocol AS P ON P.ID = D.ProtocolID LEFT OUTER JOIN dbo.Interconnection AS I ON I.ID = D.InterconnectionID LEFT OUTER JOIN dbo.Node AS N ON N.ID = D.NodeID LEFT OUTER JOIN dbo.Device AS PD ON PD.ID = D.ParentID GO CREATE VIEW [dbo].[HistorianDetail] AS SELECT H.NodeID, H.ID, H.Acronym, ISNULL(H.Name, '') AS Name, ISNULL(H.AssemblyName, '') AS AssemblyName, ISNULL(H.TypeName, '') AS TypeName, ISNULL(H.ConnectionString, '') AS ConnectionString, H.IsLocal, ISNULL(H.Description, '') AS Description, H.LoadOrder, H.Enabled, N.Name AS NodeName, H.MeasurementReportingInterval FROM dbo.Historian AS H INNER JOIN dbo.Node AS N ON H.NodeID = N.ID GO CREATE VIEW [dbo].[NodeDetail] AS SELECT N.ID, N.Name, ISNULL(N.CompanyID, 0) AS CompanyID, ISNULL(N.Longitude, 0) AS Longitude, ISNULL(N.Latitude, 0) AS Latitude, ISNULL(N.Description, '') AS Description, ISNULL(N.ImagePath, '') AS ImagePath, ISNULL(N.Settings, '') AS Settings, N.MenuType, N.MenuData, N.Master, N.LoadOrder, N.Enabled, ISNULL(C.Name, '') AS CompanyName FROM Node N LEFT JOIN Company C ON N.CompanyID = C.ID GO CREATE VIEW [dbo].[VendorDetail] AS Select ID, ISNULL(Acronym, '') AS Acronym, Name, ISNULL(PhoneNumber, '') AS PhoneNumber, ISNULL(ContactEmail, '') AS ContactEmail, ISNULL(URL, '') AS URL FROM Vendor GO CREATE VIEW [dbo].[CustomActionAdapterDetail] AS SELECT CA.NodeID, CA.ID, CA.AdapterName, CA.AssemblyName, CA.TypeName, ISNULL(CA.ConnectionString, '') AS ConnectionString, CA.LoadOrder, CA.Enabled, N.Name AS NodeName FROM dbo.CustomActionAdapter AS CA INNER JOIN dbo.Node AS N ON CA.NodeID = N.ID GO CREATE VIEW [dbo].[CustomInputAdapterDetail] AS SELECT CA.NodeID, CA.ID, CA.AdapterName, CA.AssemblyName, CA.TypeName, ISNULL(CA.ConnectionString, '') AS ConnectionString, CA.LoadOrder, CA.Enabled, N.Name AS NodeName FROM dbo.CustomInputAdapter AS CA INNER JOIN dbo.Node AS N ON CA.NodeID = N.ID GO CREATE VIEW [dbo].[CustomOutputAdapterDetail] AS SELECT CA.NodeID, CA.ID, CA.AdapterName, CA.AssemblyName, CA.TypeName, ISNULL(CA.ConnectionString, '') AS ConnectionString, CA.LoadOrder, CA.Enabled, N.Name AS NodeName FROM dbo.CustomOutputAdapter AS CA INNER JOIN dbo.Node AS N ON CA.NodeID = N.ID GO CREATE VIEW [dbo].[IaonTreeView] AS SELECT 'Action Adapters' AS AdapterType, NodeID, ID, AdapterName, AssemblyName, TypeName, ISNULL(ConnectionString, '') AS ConnectionString FROM dbo.IaonActionAdapter UNION ALL SELECT 'Input Adapters' AS AdapterType, NodeID, ID, AdapterName, AssemblyName, TypeName, ISNULL(ConnectionString, '') AS ConnectionString FROM dbo.IaonInputAdapter UNION ALL SELECT 'Output Adapters' AS AdapterType, NodeID, ID, AdapterName, AssemblyName, TypeName, ISNULL(ConnectionString, '') AS ConnectionString FROM dbo.IaonOutputAdapter GO CREATE VIEW [dbo].[OtherDeviceDetail] AS SELECT OD.ID, OD.Acronym, ISNULL(OD.Name, '') AS Name, OD.IsConcentrator, OD.CompanyID, OD.VendorDeviceID, OD.Longitude, OD.Latitude, OD.InterconnectionID, OD.Planned, OD.Desired, OD.InProgress, ISNULL(C.Name, '') AS CompanyName, ISNULL(C.Acronym, '') AS CompanyAcronym, ISNULL(C.MapAcronym, '') AS CompanyMapAcronym, ISNULL(VD.Name, '') AS VendorDeviceName, ISNULL(I.Name, '') AS InterconnectionName FROM dbo.OtherDevice AS OD LEFT OUTER JOIN dbo.Company AS C ON OD.CompanyID = C.ID LEFT OUTER JOIN dbo.VendorDevice AS VD ON OD.VendorDeviceID = VD.ID LEFT OUTER JOIN dbo.Interconnection AS I ON OD.InterconnectionID = I.ID GO CREATE VIEW [dbo].[MapData] AS SELECT 'Device' AS DeviceType, NodeID, ID, Acronym, ISNULL(Name, '') AS Name, CompanyMapAcronym, CompanyName, VendorDeviceName, Longitude, Latitude, CONVERT(BIT, '1') AS Reporting, CONVERT(BIT, '0') AS Inprogress, CONVERT(BIT, '0') AS Planned, CONVERT(BIT, '0') AS Desired FROM dbo.DeviceDetail AS D UNION ALL SELECT 'OtherDevice' AS DeviceType, NULL AS NodeID, ID, Acronym, ISNULL(Name, '') AS Name, CompanyMapAcronym, CompanyName, VendorDeviceName, Longitude, Latitude, CONVERT(BIT, '0') AS Reporting, CONVERT(BIT, '1') AS Inprogress, CONVERT(BIT, '1') AS Planned, CONVERT(BIT, '1') AS Desired FROM dbo.OtherDeviceDetail AS OD GO CREATE VIEW [dbo].[VendorDeviceDistribution] AS SELECT dbo.Device.NodeID, dbo.Vendor.Name AS VendorName, COUNT(*) AS DeviceCount FROM dbo.Device LEFT OUTER JOIN dbo.VendorDevice ON dbo.Device.VendorDeviceID = dbo.VendorDevice.ID INNER JOIN dbo.Vendor ON dbo.VendorDevice.VendorID = dbo.Vendor.ID GROUP BY dbo.Device.NodeID, dbo.Vendor.Name GO CREATE VIEW [dbo].[OutputStreamDetail] AS SELECT OS.NodeID, OS.ID, OS.Acronym, ISNULL(OS.Name, '') AS Name, OS.Type, ISNULL(OS.ConnectionString, '') AS ConnectionString, OS.IDCode, ISNULL(OS.CommandChannel, '') AS CommandChannel, ISNULL(OS.DataChannel, '') AS DataChannel, OS.AutoPublishConfigFrame, OS.AutoStartDataChannel, OS.NominalFrequency, OS.FramesPerSecond, OS.LagTime, OS.LeadTime, OS.UseLocalClockAsRealTime, OS.AllowSortsByArrival, OS.LoadOrder, OS.Enabled, N.Name AS NodeName, OS.DigitalMaskValue, OS.AnalogScalingValue, OS.VoltageScalingValue, OS.CurrentScalingValue, OS.CoordinateFormat, OS.DataFormat, OS.DownsamplingMethod, OS.AllowPreemptivePublishing, OS.TimeResolution, OS.IgnoreBadTimeStamps, OS.PerformTimeReasonabilityCheck FROM dbo.OutputStream AS OS INNER JOIN dbo.Node AS N ON OS.NodeID = N.ID GO CREATE VIEW [dbo].[OutputStreamMeasurementDetail] AS SELECT OSM.NodeID, OSM.AdapterID, OSM.ID, OSM.HistorianID, OSM.PointID, OSM.SignalReference, M.PointTag AS SourcePointTag, ISNULL(H.Acronym, '') AS HistorianAcronym FROM dbo.OutputStreamMeasurement AS OSM INNER JOIN dbo.Measurement AS M ON M.PointID = OSM.PointID LEFT OUTER JOIN dbo.Historian AS H ON H.ID = OSM.HistorianID GO CREATE VIEW [dbo].[OutputStreamDeviceDetail] AS SELECT NodeID, AdapterID, ID, Acronym, ISNULL(BpaAcronym, '') AS BpaAcronym, Name, LoadOrder, Enabled, ISNULL(PhasorDataFormat, '') AS PhasorDataFormat, ISNULL(FrequencyDataFormat, '') AS FrequencyDataFormat, ISNULL(AnalogDataFormat, '') AS AnalogDataFormat, ISNULL(CoordinateFormat, '') AS CoordinateFormat, IDCode, CASE WHEN EXISTS (SELECT Acronym FROM Device WHERE Acronym = OSD.Acronym) THEN CONVERT(bit, 0) ELSE CONVERT(bit, 1) END AS Virtual FROM dbo.OutputStreamDevice AS OSD GO CREATE VIEW [dbo].[PhasorDetail] AS SELECT P.*, ISNULL(DP.Label, '') AS DestinationPhasorLabel, D.Acronym AS DeviceAcronym FROM Phasor P LEFT OUTER JOIN Phasor DP ON P.DestinationPhasorID = DP.ID LEFT OUTER JOIN Device D ON P.DeviceID = D.ID GO CREATE VIEW [dbo].[StatisticMeasurement] AS SELECT * FROM MeasurementDetail WHERE SignalAcronym = 'STAT' GO CREATE VIEW [dbo].[SubscriberMeasurementDetail] AS SELECT SubscriberMeasurement.NodeID AS NodeID, SubscriberMeasurement.SubscriberID AS SubscriberID, Subscriber.Acronym AS SubscriberAcronym, COALESCE(Subscriber.Name, '') AS SubscriberName, SubscriberMeasurement.SignalID AS SignalID, SubscriberMeasurement.Allowed AS Allowed, Measurement.PointID AS PointID, Measurement.PointTag AS PointTag, Measurement.SignalReference AS SignalReference FROM ((SubscriberMeasurement JOIN Subscriber ON (SubscriberMeasurement.SubscriberID = Subscriber.ID)) JOIN Measurement ON (SubscriberMeasurement.SignalID = Measurement.SignalID)); GO CREATE VIEW [dbo].[SubscriberMeasGroupDetail] AS SELECT SubscriberMeasurementGroup.NodeID AS NodeID, SubscriberMeasurementGroup.SubscriberID AS SubscriberID, Subscriber.Acronym AS SubscriberAcronym, COALESCE(Subscriber.Name, '') AS SubscriberName, SubscriberMeasurementGroup.MeasurementGroupID AS MeasurementGroupID, SubscriberMeasurementGroup.Allowed AS Allowed, MeasurementGroup.Name AS MeasurementGroupName FROM ((SubscriberMeasurementGroup JOIN Subscriber ON (SubscriberMeasurementGroup.SubscriberID = Subscriber.ID)) JOIN MeasurementGroup ON (SubscriberMeasurementGroup.MeasurementGroupID = MeasurementGroup.ID)); GO CREATE VIEW [dbo].[MeasurementGroupMeasDetail] AS SELECT MeasurementGroupMeasurement.MeasurementGroupID AS MeasurementGroupID, MeasurementGroup.Name AS MeasurementGroupName, MeasurementGroupMeasurement.SignalID AS SignalID, Measurement.PointID AS PointID, Measurement.PointTag AS PointTag, Measurement.SignalReference AS SignalReference FROM ((MeasurementGroupMeasurement JOIN MeasurementGroup ON (MeasurementGroupMeasurement.MeasurementGroupID = MeasurementGroup.ID)) JOIN Measurement ON (MeasurementGroupMeasurement.SignalID = Measurement.SignalID)); GO ALTER TABLE [dbo].[OtherDevice] WITH CHECK ADD CONSTRAINT [FK_OtherDevice_Company] FOREIGN KEY([CompanyID]) REFERENCES [dbo].[Company] ([ID]) GO ALTER TABLE [dbo].[OtherDevice] WITH CHECK ADD CONSTRAINT [FK_OtherDevice_Interconnection] FOREIGN KEY([InterconnectionID]) REFERENCES [dbo].[Interconnection] ([ID]) GO ALTER TABLE [dbo].[OtherDevice] WITH CHECK ADD CONSTRAINT [FK_OtherDevice_VendorDevice] FOREIGN KEY([VendorDeviceID]) REFERENCES [dbo].[VendorDevice] ([ID]) GO ALTER TABLE [dbo].[Node] WITH CHECK ADD CONSTRAINT [FK_Node_Company] FOREIGN KEY([CompanyID]) REFERENCES [dbo].[Company] ([ID]) GO ALTER TABLE [dbo].[DataOperation] WITH CHECK ADD CONSTRAINT [FK_DataOperation_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[Device] WITH CHECK ADD CONSTRAINT [FK_Device_Company] FOREIGN KEY([CompanyID]) REFERENCES [dbo].[Company] ([ID]) GO ALTER TABLE [dbo].[Device] WITH CHECK ADD CONSTRAINT [FK_Device_Device] FOREIGN KEY([ParentID]) REFERENCES [dbo].[Device] ([ID]) GO ALTER TABLE [dbo].[Device] WITH CHECK ADD CONSTRAINT [FK_Device_Interconnection] FOREIGN KEY([InterconnectionID]) REFERENCES [dbo].[Interconnection] ([ID]) GO ALTER TABLE [dbo].[Device] WITH CHECK ADD CONSTRAINT [FK_Device_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[Device] WITH CHECK ADD CONSTRAINT [FK_Device_Protocol] FOREIGN KEY([ProtocolID]) REFERENCES [dbo].[Protocol] ([ID]) GO ALTER TABLE [dbo].[Device] WITH CHECK ADD CONSTRAINT [FK_Device_VendorDevice] FOREIGN KEY([VendorDeviceID]) REFERENCES [dbo].[VendorDevice] ([ID]) GO ALTER TABLE [dbo].[VendorDevice] WITH CHECK ADD CONSTRAINT [FK_VendorDevice_Vendor] FOREIGN KEY([VendorID]) REFERENCES [dbo].[Vendor] ([ID]) GO ALTER TABLE [dbo].[OutputStreamDeviceDigital] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDeviceDigital_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[OutputStreamDeviceDigital] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDeviceDigital_OutputStreamDevice] FOREIGN KEY([OutputStreamDeviceID]) REFERENCES [dbo].[OutputStreamDevice] ([ID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[OutputStreamDevicePhasor] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDevicePhasor_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[OutputStreamDevicePhasor] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDevicePhasor_OutputStreamDevice] FOREIGN KEY([OutputStreamDeviceID]) REFERENCES [dbo].[OutputStreamDevice] ([ID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[OutputStreamDeviceAnalog] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDeviceAnalog_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[OutputStreamDeviceAnalog] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDeviceAnalog_OutputStreamDevice] FOREIGN KEY([OutputStreamDeviceID]) REFERENCES [dbo].[OutputStreamDevice] ([ID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[Measurement] WITH CHECK ADD CONSTRAINT [FK_Measurement_Device] FOREIGN KEY([DeviceID]) REFERENCES [dbo].[Device] ([ID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[Measurement] WITH CHECK ADD CONSTRAINT [FK_Measurement_SignalType] FOREIGN KEY([SignalTypeID]) REFERENCES [dbo].[SignalType] ([ID]) GO ALTER TABLE [dbo].[ImportedMeasurement] WITH CHECK ADD CONSTRAINT [FK_ImportedMeasurement_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[OutputStreamMeasurement] WITH CHECK ADD CONSTRAINT [FK_OutputStreamMeasurement_Historian] FOREIGN KEY([HistorianID]) REFERENCES [dbo].[Historian] ([ID]) GO ALTER TABLE [dbo].[OutputStreamMeasurement] WITH CHECK ADD CONSTRAINT [FK_OutputStreamMeasurement_Measurement] FOREIGN KEY([PointID]) REFERENCES [dbo].[Measurement] ([PointID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[OutputStreamMeasurement] WITH CHECK ADD CONSTRAINT [FK_OutputStreamMeasurement_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[OutputStreamMeasurement] WITH CHECK ADD CONSTRAINT [FK_OutputStreamMeasurement_OutputStream] FOREIGN KEY([AdapterID]) REFERENCES [dbo].[OutputStream] ([ID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[OutputStreamDevice] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDevice_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) GO ALTER TABLE [dbo].[OutputStreamDevice] WITH CHECK ADD CONSTRAINT [FK_OutputStreamDevice_OutputStream] FOREIGN KEY([AdapterID]) REFERENCES [dbo].[OutputStream] ([ID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[Phasor] WITH CHECK ADD CONSTRAINT [FK_Phasor_Device] FOREIGN KEY([DeviceID]) REFERENCES [dbo].[Device] ([ID]) ON DELETE CASCADE GO ALTER TABLE [dbo].[Phasor] WITH CHECK ADD CONSTRAINT [FK_Phasor_Phasor] FOREIGN KEY([DestinationPhasorID]) REFERENCES [dbo].[Phasor] ([ID]) GO ALTER TABLE [dbo].[CalculatedMeasurement] WITH CHECK ADD CONSTRAINT [FK_CalculatedMeasurement_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[CustomActionAdapter] WITH CHECK ADD CONSTRAINT [FK_CustomActionAdapter_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[Historian] WITH CHECK ADD CONSTRAINT [FK_Historian_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[CustomInputAdapter] WITH CHECK ADD CONSTRAINT [FK_CustomInputAdapter_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[OutputStream] WITH CHECK ADD CONSTRAINT [FK_OutputStream_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[Alarm] WITH CHECK ADD CONSTRAINT [FK_Alarm_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[Alarm] WITH CHECK ADD CONSTRAINT [FK_Alarm_Measurement_SignalID] FOREIGN KEY([SignalID]) REFERENCES [dbo].[Measurement] ([SignalID]) ON UPDATE CASCADE ON DELETE CASCADE GO ALTER TABLE [dbo].[Alarm] WITH CHECK ADD CONSTRAINT [FK_Alarm_Measurement_AssociatedMeasurementID] FOREIGN KEY([SignalID]) REFERENCES [dbo].[Measurement] ([SignalID]) GO ALTER TABLE [dbo].[CustomOutputAdapter] WITH CHECK ADD CONSTRAINT [FK_CustomOutputAdapter_Node] FOREIGN KEY([NodeID]) REFERENCES [dbo].[Node] ([ID]) ON UPDATE CASCADE ON DELETE CASCADE GO /* GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE PROCEDURE [GetFormattedMeasurements] @measurementSql NVARCHAR(max), @includeAdjustments BIT, @measurements NVARCHAR(max) OUTPUT AS -- Fill the table variable with the rows for your result set DECLARE @measurementID INT DECLARE @archiveSource NVARCHAR(50) DECLARE @adder FLOAT DECLARE @multiplier FLOAT SET @measurements = '' CREATE TABLE #temp ( [MeasurementID] INT, [ArchiveSource] NVARCHAR(50), [Adder] FLOAT, [Multiplier] FLOAT ) INSERT INTO #temp EXEC sp_executesql @measurementSql DECLARE SelectedMeasurements CURSOR LOCAL FAST_FORWARD FOR SELECT * FROM #temp OPEN SelectedMeasurements -- Get first row from measurements SQL FETCH NEXT FROM SelectedMeasurements INTO @measurementID, @archiveSource, @adder, @multiplier -- Step through selected measurements WHILE @@FETCH_STATUS = 0 BEGIN IF LEN(@measurements) > 0 SET @measurements = @measurements + ';' IF @includeAdjustments <> 0 AND (@adder <> 0.0 OR @multiplier <> 1.0) SET @measurements = @measurements + @archiveSource + ':' + @measurementID + ',' + @adder + ',' + @multiplier ELSE SET @measurements = @measurements + @archiveSource + ':' + @measurementID -- Get next row from measurements SQL FETCH NEXT FROM SelectedMeasurements INTO @measurementID, @archiveSource, @adder, @multiplier END CLOSE SelectedMeasurements DEALLOCATE SelectedMeasurements DROP TABLE #temp GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE FUNCTION [FormatMeasurements] (@measurementSql NVARCHAR(max), @includeAdjustments BIT) RETURNS NVARCHAR(max) AS BEGIN DECLARE @measurements NVARCHAR(max) SET @measurements = '' EXEC GetFormattedMeasurements @measurementSql, @includeAdjustments, @measurements IF LEN(@measurements) > 0 SET @measurements = '{' + @measurements + '}' ELSE SET @measurements = NULL RETURN @measurements END GO */