This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
db:sqlserver:jimetrics [2014/09/16 20:56] 127.0.0.1 external edit |
db:sqlserver:jimetrics [2018/05/14 22:00] (current) |
||
---|---|---|---|
Line 1: | Line 1: | ||
==== JiMetrics database creation ==== | ==== JiMetrics database creation ==== | ||
- | Since I started with Windows, I will present a SQL Server database script first. Please note that metrics data is typically write-once and read-only, so column-store tables are perfect fits. InfoBright's Community Edition is a column store database engine and it is free. I recommend using it and I really doubt that we will need to purge historical metrics data if we use that. Or at a minimum, we would be able to keep that history much longer. | + | Since I started with Windows, I will present a SQL Server database design first. Metrics data is typically write-once and read-only, so column-store tables are perfect fits. Toward that end, I've created two versions: the first one, listed below as JiMetrics.sql, is a regular row-based database. The second one uses columnstore for many tables. It is based on SQL Server 2014. It is listed below as JiMetricsColumnstore.sql. |
+ | |||
+ | I doubt that we will need to purge historical metrics data if we use columnstore. Or at a minimum, we would be able to keep that history much longer. | ||
Here is the ER diagram of the JiMetrics database. For now there are only 7 tables involved under the Windows schema, so it is pretty easy to understand and query. | Here is the ER diagram of the JiMetrics database. For now there are only 7 tables involved under the Windows schema, so it is pretty easy to understand and query. | ||
Line 439: | Line 441: | ||
, @Value sql_variant | , @Value sql_variant | ||
, @ValueInUse sql_variant | , @ValueInUse sql_variant | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | INSERT INTO Windows.InstanceConfig ( | ||
+ | InstanceID | ||
+ | , ConfigurationID | ||
+ | , Name | ||
+ | , Value | ||
+ | , ValueInUse) | ||
+ | VALUES ( | ||
+ | @InstanceID | ||
+ | , @ConfigurationID | ||
+ | , @Name | ||
+ | , @Value | ||
+ | , @ValueInUse); | ||
+ | END | ||
+ | GO | ||
+ | IF NOT EXISTS ( SELECT * | ||
+ | FROM [sys].[tables] | ||
+ | WHERE [name] = N'InstanceDmvPerfCounter' | ||
+ | AND [type] = N'U' ) | ||
+ | CREATE TABLE [Windows].[InstanceDmvPerfCounter] | ||
+ | ( | ||
+ | [InstanceDmvPerfCounterID] [int] IDENTITY(1,1) NOT NULL, | ||
+ | [InstanceID] [int] NOT NULL, | ||
+ | [object_name] [nvarchar](128) NOT NULL , | ||
+ | [counter_name] [nvarchar](128) NOT NULL , | ||
+ | [instance_name] [nvarchar](128) NULL , | ||
+ | [cntr_value] [bigint] NOT NULL , | ||
+ | [cntr_type] [int] NOT NULL , | ||
+ | [CollectionDate] [datetime2] NOT NULL, | ||
+ | CONSTRAINT [pk__InstanceDmvPerfCounter_ID] PRIMARY KEY CLUSTERED | ||
+ | ([InstanceDmvPerfCounterID] ASC) | ||
+ | WITH (DATA_COMPRESSION = PAGE)); | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[InstanceDmvPerfCounter] | ||
+ | ADD DEFAULT (getdate()) FOR [CollectionDate]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[InstanceDmvPerfCounter] ADD CONSTRAINT | ||
+ | [FK_InstanceDmvPerfCounter_InstanceID] FOREIGN KEY (InstanceID) | ||
+ | REFERENCES [Windows].[Instance] (InstanceID); | ||
+ | GO | ||
+ | |||
+ | CREATE PROCEDURE [Windows].[InstanceDmvPerfCounter_Insert] | ||
+ | @InstanceID int | ||
+ | , @object_name nvarchar(128) | ||
+ | , @counter_name nvarchar(128) | ||
+ | , @instance_name nvarchar(128) | ||
+ | , @cntr_value bigint | ||
+ | , @cntr_type int | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | INSERT INTO Windows.InstanceDmvPerfCounter ( | ||
+ | InstanceID | ||
+ | , object_name | ||
+ | , counter_name | ||
+ | , instance_name | ||
+ | , cntr_value | ||
+ | , cntr_type) | ||
+ | VALUES ( | ||
+ | @InstanceID | ||
+ | , @object_name | ||
+ | , @counter_name | ||
+ | , @instance_name | ||
+ | , @cntr_value | ||
+ | , @cntr_type); | ||
+ | END | ||
+ | GO | ||
+ | </code> | ||
+ | |||
+ | JiMetrics with columnstore, designed and tested against SQL Server 2014. | ||
+ | <code tsql JiMetricsColumnstore.sql> | ||
+ | CREATE DATABASE JiMetrics; | ||
+ | GO | ||
+ | ALTER DATABASE JiMetrics SET RECOVERY SIMPLE; | ||
+ | GO | ||
+ | USE [JiMetrics]; | ||
+ | GO | ||
+ | |||
+ | IF EXISTS (SELECT * FROM sys.schemas WHERE name = N'Windows') | ||
+ | DROP SCHEMA [Windows]; | ||
+ | GO | ||
+ | |||
+ | CREATE SCHEMA [Windows] AUTHORIZATION [dbo]; | ||
+ | GO | ||
+ | |||
+ | SET ANSI_NULLS ON; | ||
+ | GO | ||
+ | |||
+ | SET QUOTED_IDENTIFIER ON; | ||
+ | GO | ||
+ | |||
+ | CREATE TABLE [Windows].[Host]( | ||
+ | [HostID] [int] IDENTITY(1,1) NOT NULL, | ||
+ | [HostName] [nvarchar](20) NOT NULL, | ||
+ | [Domain] [nvarchar](50) NULL, | ||
+ | [OS] [nvarchar](50) NULL, | ||
+ | [OSArchitecture] [nchar](6) NULL, | ||
+ | [OSServicePack] [nvarchar](20) NULL, | ||
+ | [OSVersionNumber] [nvarchar](20) NULL, | ||
+ | [HardwareModel] [nvarchar](50) NULL, | ||
+ | [HardwareVendor] [nvarchar](50) NULL, | ||
+ | [MemorySizeGB] [int] NULL, | ||
+ | [CPUType] [nvarchar] (50) NULL, | ||
+ | [CoreCount] [int] NULL, | ||
+ | [SMBIOSVersion] [nvarchar](50) NULL, | ||
+ | [BIOSReleaseDate] [DATE] NULL, | ||
+ | [SerialNumber] [nvarchar](50) NULL, | ||
+ | [IsVM] AS (CASE HardwareVendor | ||
+ | WHEN 'innotek GmbH' THEN 'Y' | ||
+ | WHEN 'microsoft' THEN 'Y' | ||
+ | WHEN 'xen' THEN 'Y' | ||
+ | ELSE 'N' | ||
+ | END) PERSISTED, | ||
+ | [IsActive] [nchar](1) NOT NULL, | ||
+ | [LastUpdate] [datetime2] NULL | ||
+ | CONSTRAINT [PK_Host] PRIMARY KEY CLUSTERED ([HostID]), | ||
+ | CONSTRAINT [UNQ_HostName] UNIQUE NONCLUSTERED ([HostName]) | ||
+ | WITH (DATA_COMPRESSION = PAGE)); | ||
+ | |||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Host] WITH CHECK ADD CONSTRAINT | ||
+ | [CK_Host_IsActive] CHECK (([IsActive]='N' OR [IsActive]='n' OR | ||
+ | [IsActive]='Y' OR [IsActive]='y')); | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Host] CHECK CONSTRAINT [CK_Host_IsActive]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Host] ADD CONSTRAINT [DF_Host_IsActive] | ||
+ | DEFAULT ('Y') FOR [IsActive]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Host] ADD CONSTRAINT [DF_Host_LastUpdate] | ||
+ | DEFAULT (getdate()) FOR [LastUpdate]; | ||
+ | GO | ||
+ | |||
+ | CREATE PROCEDURE Windows.Host_Select_HostID_HostName | ||
+ | @IsActive nchar(1) = 'Y' | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | SELECT HostID, HostName FROM Windows.Host | ||
+ | WHERE IsActive = @IsActive; | ||
+ | END | ||
+ | GO | ||
+ | CREATE PROCEDURE Windows.Host_Update | ||
+ | @HostID int = 0 | ||
+ | , @Domain nvarchar(50) = NULL | ||
+ | , @OS nvarchar(50) = NULL | ||
+ | , @OSArchitecture nchar(6) = NULL | ||
+ | , @OSServicePack nvarchar(20) = NULL | ||
+ | , @OSVersionNumber nvarchar(20) = NULL | ||
+ | , @HardwareModel nvarchar(50) = NULL | ||
+ | , @HardwareVendor nvarchar(50) = NULL | ||
+ | , @MemorySizeGB int = NULL | ||
+ | , @CPUType nvarchar(50) = NULL | ||
+ | , @CoreCount int = NULL | ||
+ | , @SMBIOSVersion nvarchar(50) = NULL | ||
+ | , @BIOSReleaseDate DATE = NULL | ||
+ | , @SerialNumber nvarchar(50) = NULL | ||
+ | , @IsActive nchar(1) = 'Y' | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | UPDATE Windows.Host SET | ||
+ | Domain = @Domain | ||
+ | , OS = @OS | ||
+ | , OSArchitecture = @OSArchitecture | ||
+ | , OSServicePack = @OSServicePack | ||
+ | , OSVersionNumber = @OSVersionNumber | ||
+ | , HardwareModel = @HardwareModel | ||
+ | , HardwareVendor = @HardwareVendor | ||
+ | , MemorySizeGB = @MemorySizeGB | ||
+ | , CPUType = @CPUType | ||
+ | , CoreCount = @CoreCount | ||
+ | , SMBIOSVersion = @SMBIOSVersion | ||
+ | , BIOSReleaseDate = @BIOSReleaseDate | ||
+ | , SerialNumber = @SerialNumber | ||
+ | , IsActive = @IsActive | ||
+ | WHERE HostID = @HostID; | ||
+ | END | ||
+ | GO | ||
+ | INSERT INTO Windows.Host (HostName) VALUES ('sql1'); | ||
+ | INSERT INTO Windows.Host (HostName) VALUES ('sql2'); | ||
+ | |||
+ | |||
+ | CREATE TABLE [Windows].[Instance]( | ||
+ | [InstanceID] [int] IDENTITY(1,1) NOT NULL, | ||
+ | [HostID] [int] NOT NULL, | ||
+ | [InstanceName] [nvarchar](30) NOT NULL, | ||
+ | [StartupAcct] [nvarchar](30) NOT NULL, | ||
+ | [InstanceEdition] [nvarchar](50) NULL, | ||
+ | [InstanceEditionID] [bigint] NULL, | ||
+ | [InstanceVersion] [nchar](20) NULL, | ||
+ | [InstanceServicePack] [nvarchar](20) NULL, | ||
+ | [IsActive] [nchar](1) NOT NULL, | ||
+ | [LastUpdate] [datetime2] NULL | ||
+ | CONSTRAINT [PK_Instance] PRIMARY KEY CLUSTERED ([InstanceID]), | ||
+ | CONSTRAINT [UNQ_InstanceName] UNIQUE NONCLUSTERED ([InstanceName]) | ||
+ | WITH (DATA_COMPRESSION = PAGE)); | ||
+ | |||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Instance] WITH CHECK ADD CONSTRAINT | ||
+ | [CK_Instance_IsActive] CHECK (([IsActive]='N' OR [IsActive]='n' OR | ||
+ | [IsActive]='Y' OR [IsActive]='y')); | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Instance] CHECK CONSTRAINT | ||
+ | [CK_Instance_IsActive]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Instance] ADD CONSTRAINT [DF_Instance_IsActive] | ||
+ | DEFAULT ('Y') FOR [IsActive]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Instance] ADD CONSTRAINT | ||
+ | [DF_Instance_LastUpdate] DEFAULT (getdate()) FOR [LastUpdate]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Instance] ADD CONSTRAINT [FK_Instance_HostID] | ||
+ | FOREIGN KEY (HostID) REFERENCES [Windows].[Host] (HostID); | ||
+ | GO | ||
+ | |||
+ | CREATE PROCEDURE Windows.Instance_Select_InstanceID_InstanceName | ||
+ | @IsActive nchar(1) = 'Y' | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | SELECT InstanceID, InstanceName FROM Windows.Instance | ||
+ | WHERE IsActive = @IsActive; | ||
+ | END | ||
+ | GO | ||
+ | |||
+ | CREATE PROCEDURE Windows.Instance_Insert | ||
+ | @HostID int | ||
+ | , @InstanceName nvarchar(30) | ||
+ | , @StartupAcct nvarchar(30) | ||
+ | , @IsActive nvarchar(1) | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | IF NOT EXISTS (SELECT * FROM Windows.Instance | ||
+ | WHERE InstanceName = @InstanceName) | ||
+ | INSERT INTO [Windows].[Instance] (HostID, InstanceName, StartupAcct, | ||
+ | IsActive) VALUES (@HostID, @InstanceName, @StartupAcct, @IsActive); | ||
+ | END | ||
+ | GO | ||
+ | |||
+ | CREATE PROCEDURE Windows.Instance_Update | ||
+ | @InstanceID int = 0 | ||
+ | , @InstanceEdition nvarchar(50) = NULL | ||
+ | , @InstanceEditionID bigint = NULL | ||
+ | , @InstanceVersion nvarchar(20) = NULL | ||
+ | , @InstanceServicePack nvarchar(20) = NULL | ||
+ | , @StartupAcct nvarchar(30) = NULL | ||
+ | , @IsActive nchar(1) = 'Y' | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | UPDATE Windows.Instance SET | ||
+ | InstanceEdition = @InstanceEdition | ||
+ | , InstanceEditionID = @InstanceEditionID | ||
+ | , InstanceVersion = @InstanceVersion | ||
+ | , InstanceServicePack = @InstanceServicePack | ||
+ | , StartupAcct = @StartupAcct | ||
+ | , IsActive = @IsActive | ||
+ | WHERE InstanceID = @InstanceID; | ||
+ | END | ||
+ | GO | ||
+ | |||
+ | CREATE TABLE [Windows].[Storage]( | ||
+ | [RecordID] [int] IDENTITY(1,1) NOT NULL | ||
+ | , [HostID] [int] NOT NULL | ||
+ | , [DiskPath] [nvarchar](300) NOT NULL | ||
+ | , [DiskFormat] [nvarchar](25) NOT NULL | ||
+ | , [DiskLabel] [nvarchar](100) NULL | ||
+ | , [DiskSizeGB] [int] NOT NULL | ||
+ | , [DiskFreeGB] [int] NOT NULL | ||
+ | , [CollectionDate] [datetime2] NOT NULL) | ||
+ | WITH (DATA_COMPRESSION = PAGE); | ||
+ | |||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Storage] | ||
+ | ADD DEFAULT (getdate()) FOR [CollectionDate]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Storage] WITH CHECK ADD CONSTRAINT | ||
+ | [ck__Storage_DiskSize] CHECK (([DiskSizeGB]>=(0) AND [DiskFreeGB]>=(0))); | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[Storage] | ||
+ | CHECK CONSTRAINT [ck__Storage_DiskSize]; | ||
+ | GO | ||
+ | |||
+ | CREATE CLUSTERED COLUMNSTORE INDEX cci_Storage_ ON [Windows].[Storage] | ||
+ | GO | ||
+ | |||
+ | CREATE procedure [Windows].[Storage_Insert] | ||
+ | @HostID [int] | ||
+ | , @DiskPath [nvarchar](1000) | ||
+ | , @DiskFormat [nvarchar](50) | ||
+ | , @DiskLabel [nvarchar](100) | ||
+ | , @DiskSizeGB [int] | ||
+ | , @DiskFreeGB [int] | ||
+ | AS | ||
+ | |||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | INSERT INTO Windows.Storage ( | ||
+ | HostID | ||
+ | , DiskPath | ||
+ | , DiskFormat | ||
+ | , DiskLabel | ||
+ | , DiskSizeGB | ||
+ | , DiskFreeGB) | ||
+ | VALUES ( | ||
+ | @HostID | ||
+ | , @DiskPath | ||
+ | , @DiskFormat | ||
+ | , @DiskLabel | ||
+ | , @DiskSizeGB | ||
+ | , @DiskFreeGB); | ||
+ | END | ||
+ | GO | ||
+ | |||
+ | CREATE TABLE [Windows].[DbFileStats]( | ||
+ | [DbFileStatsID] [int] IDENTITY(1,1) NOT NULL, | ||
+ | [InstanceID] [int] NOT NULL, | ||
+ | [DbName] [sysname] NOT NULL, | ||
+ | [FileLogicalName] [sysname] NOT NULL, | ||
+ | [FilePhysicalName] [sysname] NOT NULL, | ||
+ | [FileGroupName] [sysname] NOT NULL, | ||
+ | [FileSizeInMB] [int] NOT NULL, | ||
+ | [FreeSizeInMB] [int] NOT NULL, | ||
+ | [Max_Size] [int] NOT NULL, | ||
+ | [Growth] [int] NOT NULL, | ||
+ | [Is_Percent_Growth] nchar(1) NOT NULL, | ||
+ | [CollectionDate] [datetime2] NOT NULL) | ||
+ | WITH (DATA_COMPRESSION = PAGE); | ||
+ | |||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[DbFileStats] | ||
+ | ADD DEFAULT (getdate()) FOR [CollectionDate]; | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[DbFileStats] WITH CHECK ADD CONSTRAINT | ||
+ | [CK_DbFileStats_Is_Percent_Growth] CHECK | ||
+ | (([Is_Percent_Growth]='N' OR [Is_Percent_Growth]='n' OR | ||
+ | [Is_Percent_Growth]='Y' OR [Is_Percent_Growth]='y')); | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[DbFileStats] ADD CONSTRAINT | ||
+ | [DF_DbFileStats_Is_Percent_Growth] DEFAULT ('N') FOR | ||
+ | [Is_Percent_Growth]; | ||
+ | GO | ||
+ | |||
+ | CREATE CLUSTERED COLUMNSTORE INDEX cci_DbFileStats ON [Windows].[DbFileStats] | ||
+ | GO | ||
+ | |||
+ | CREATE PROCEDURE [Windows].[DbFileStats_Insert] | ||
+ | @InstanceID int | ||
+ | , @DbName sysname | ||
+ | , @FileLogicalName sysname | ||
+ | , @FilePhysicalName nvarchar(500) | ||
+ | , @FileGroupName sysname | ||
+ | , @FileSizeInMB [int] | ||
+ | , @FreeSizeInMB [int] | ||
+ | , @max_size [int] | ||
+ | , @growth [int] | ||
+ | , @is_percent_growth nchar(1) | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | |||
+ | INSERT INTO Windows.DbFileStats ( | ||
+ | InstanceID | ||
+ | , DbName | ||
+ | , FileLogicalName | ||
+ | , FilePhysicalName | ||
+ | , FileGroupName | ||
+ | , FileSizeInMB | ||
+ | , FreeSizeInMB | ||
+ | , max_size | ||
+ | , growth | ||
+ | , is_percent_growth) | ||
+ | VALUES ( | ||
+ | @InstanceID | ||
+ | , @DbName | ||
+ | , @FileLogicalName | ||
+ | , @FilePhysicalName | ||
+ | , @FileGroupName | ||
+ | , @FileSizeInMB | ||
+ | , @FreeSizeInMB | ||
+ | , @max_size | ||
+ | , @growth | ||
+ | , @is_percent_growth); | ||
+ | END | ||
+ | |||
+ | GO | ||
+ | |||
+ | CREATE TABLE [Windows].[TableStats]( | ||
+ | [TableStatsID] [int] IDENTITY(1,1) NOT NULL, | ||
+ | [InstanceID] [int] NOT NULL, | ||
+ | [DbName] [sysname] NOT NULL, | ||
+ | [SchemaName] [sysname] NOT NULL, | ||
+ | [TableName] [sysname] NOT NULL, | ||
+ | [TotalRowCount] [bigint] NOT NULL, | ||
+ | [DataSizeInMB] [int] NOT NULL, | ||
+ | [IndexSizeInMB] [int] NOT NULL, | ||
+ | [CollectionDate] [datetime2] NOT NULL) | ||
+ | WITH (DATA_COMPRESSION = PAGE); | ||
+ | |||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[TableStats] ADD | ||
+ | DEFAULT (getdate()) FOR [CollectionDate]; | ||
+ | GO | ||
+ | |||
+ | CREATE CLUSTERED COLUMNSTORE INDEX cci_TableStats ON [Windows].[TableStats] | ||
+ | GO | ||
+ | |||
+ | CREATE procedure [Windows].[TableStats_Insert] | ||
+ | @InstanceID int, | ||
+ | @DbName sysname, | ||
+ | @SchemaName sysname, | ||
+ | @TableName sysname, | ||
+ | @TotalRowCount bigint, | ||
+ | @DataSizeInMB int, | ||
+ | @IndexSizeInMB int | ||
+ | AS | ||
+ | BEGIN | ||
+ | SET NOCOUNT ON; | ||
+ | INSERT INTO Windows.TableStats (InstanceID, DbName, SchemaName, | ||
+ | TableName, TotalRowCount, DataSizeInMB, IndexSizeInMB) | ||
+ | VALUES (@InstanceID, @DbName, @SchemaName, @TableName, | ||
+ | @TotalRowCount, @DataSizeInMB, @IndexSizeInMB); | ||
+ | END | ||
+ | |||
+ | GO | ||
+ | |||
+ | IF NOT EXISTS ( SELECT * | ||
+ | FROM [sys].[tables] | ||
+ | WHERE [name] = N'InstanceConfig' | ||
+ | AND [type] = N'U' ) | ||
+ | CREATE TABLE [Windows].[InstanceConfig] | ||
+ | ( | ||
+ | [InstanceConfigID] [int] IDENTITY(1,1) NOT NULL, | ||
+ | [InstanceID] [int] NOT NULL, | ||
+ | [ConfigurationID] [int] NOT NULL , | ||
+ | [Name] [nvarchar](35) NOT NULL , | ||
+ | [Value] [int] NULL , | ||
+ | [ValueInUse] [int] NULL , | ||
+ | [CollectionDate] [datetime2] NOT NULL) | ||
+ | WITH (DATA_COMPRESSION = PAGE); | ||
+ | GO | ||
+ | |||
+ | ALTER TABLE [Windows].[InstanceConfig] | ||
+ | ADD DEFAULT (getdate()) FOR [CollectionDate]; | ||
+ | GO | ||
+ | |||
+ | CREATE CLUSTERED COLUMNSTORE INDEX cci_InstanceConfig ON [Windows].[InstanceConfig] | ||
+ | GO | ||
+ | |||
+ | CREATE PROCEDURE [Windows].[InstanceConfig_Insert] | ||
+ | @InstanceID int | ||
+ | , @ConfigurationID int | ||
+ | , @Name nvarchar(35) | ||
+ | , @Value int | ||
+ | , @ValueInUse int | ||
AS | AS | ||
BEGIN | BEGIN |