<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://www.heurekaslu.se/w/index.php?action=history&amp;feed=atom&amp;title=Heureka_database_upgrade_script_0.5.1</id>
	<title>Heureka database upgrade script 0.5.1 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://www.heurekaslu.se/w/index.php?action=history&amp;feed=atom&amp;title=Heureka_database_upgrade_script_0.5.1"/>
	<link rel="alternate" type="text/html" href="https://www.heurekaslu.se/w/index.php?title=Heureka_database_upgrade_script_0.5.1&amp;action=history"/>
	<updated>2026-05-05T17:43:52Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.35.13</generator>
	<entry>
		<id>https://www.heurekaslu.se/w/index.php?title=Heureka_database_upgrade_script_0.5.1&amp;diff=2781&amp;oldid=prev</id>
		<title>Peder at 13:51, 14 July 2009</title>
		<link rel="alternate" type="text/html" href="https://www.heurekaslu.se/w/index.php?title=Heureka_database_upgrade_script_0.5.1&amp;diff=2781&amp;oldid=prev"/>
		<updated>2009-07-14T13:51:56Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left diff-editfont-monospace&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 13:51, 14 July 2009&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot; &gt;Line 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[&lt;del class=&quot;diffchange diffchange-inline&quot;&gt;Heureka database upgrade &lt;/del&gt;scripts | Back to scripts]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[&lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;:Category:Database &lt;/ins&gt;scripts | Back to scripts]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;pre&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;pre&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;IF (SELECT COUNT(*) FROM VERSION WHERE ApplicationVersion = '0.4.4.3' OR ApplicationVersion = '0.5.1.0' ) = 0&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;IF (SELECT COUNT(*) FROM VERSION WHERE ApplicationVersion = '0.4.4.3' OR ApplicationVersion = '0.5.1.0' ) = 0&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l313&quot; &gt;Line 313:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 313:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;/pre&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&amp;lt;/pre&amp;gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Database]]&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[Category:Database &lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;scripts&lt;/ins&gt;]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Peder</name></author>
	</entry>
	<entry>
		<id>https://www.heurekaslu.se/w/index.php?title=Heureka_database_upgrade_script_0.5.1&amp;diff=1195&amp;oldid=prev</id>
		<title>Cawa2: New page:  Back to scripts &lt;pre&gt; IF (SELECT COUNT(*) FROM VERSION WHERE ApplicationVersion = '0.4.4.3' OR ApplicationVersion = '0.5.1.0' ) = 0 BEGIN 	PRINT 'Wro...</title>
		<link rel="alternate" type="text/html" href="https://www.heurekaslu.se/w/index.php?title=Heureka_database_upgrade_script_0.5.1&amp;diff=1195&amp;oldid=prev"/>
		<updated>2009-02-04T14:14:16Z</updated>

		<summary type="html">&lt;p&gt;New page: &lt;a href=&quot;/w/index.php?title=Heureka_database_upgrade_scripts&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Heureka database upgrade scripts (page does not exist)&quot;&gt; Back to scripts&lt;/a&gt; &amp;lt;pre&amp;gt; IF (SELECT COUNT(*) FROM VERSION WHERE ApplicationVersion = &amp;#039;0.4.4.3&amp;#039; OR ApplicationVersion = &amp;#039;0.5.1.0&amp;#039; ) = 0 BEGIN 	PRINT &amp;#039;Wro...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[Heureka database upgrade scripts | Back to scripts]]&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
IF (SELECT COUNT(*) FROM VERSION WHERE ApplicationVersion = '0.4.4.3' OR ApplicationVersion = '0.5.1.0' ) = 0&lt;br /&gt;
BEGIN&lt;br /&gt;
	PRINT 'Wrong Version of database. You must upgrade to version 0.4.4.3 before running this script.';&lt;br /&gt;
	SELECT ApplicationVersion FROM VERSION;&lt;br /&gt;
END&lt;br /&gt;
ELSE &lt;br /&gt;
BEGIN&lt;br /&gt;
&lt;br /&gt;
	-- 1. Add columns for to InvReferenceunit&lt;br /&gt;
&lt;br /&gt;
	IF NOT EXISTS (SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'InvReferenceunit' AND COLUMN_NAME = 'TotalBasalArea')&lt;br /&gt;
	BEGIN&lt;br /&gt;
			ALTER TABLE InvReferenceunit ADD&lt;br /&gt;
				[TotalBasalArea] [real] NULL&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- Creates all 8 tables related to Stratification: &lt;br /&gt;
	-- Tables: Stratification, StratificationInterval,Stratum,StratumCondition,StratumConditionDetail,&lt;br /&gt;
	-- StratumConditionDetailValue,StratumConditionJunction,StratumStandObjectJunction&lt;br /&gt;
&lt;br /&gt;
	-- 1. Create Stratification table&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.Stratification','U') IS NULL&lt;br /&gt;
	BEGIN&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[Stratification](&lt;br /&gt;
			[StratificationGUID] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[Description] [varchar](50) NULL,&lt;br /&gt;
			[Date] [datetime] NULL,&lt;br /&gt;
			[StandRegisterId] [int] NULL,&lt;br /&gt;
			[ValueColumnIndex] [int] NULL,&lt;br /&gt;
			[DepartmentCount] [int] NULL,&lt;br /&gt;
			[MaxAreaProportion] [int] NULL,&lt;br /&gt;
			[Frozen] [bit] NULL,&lt;br /&gt;
		 CONSTRAINT [PK_Stratification] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[StratificationGUID] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		SET ANSI_PADDING OFF;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Name or short description' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratification', @level2type=N'COLUMN',@level2name=N'Description';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Date when stratification was created' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratification', @level2type=N'COLUMN',@level2name=N'Date';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Id for standregister that this stratification works with' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratification', @level2type=N'COLUMN',@level2name=N'StandRegisterId';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'The index of the value that will show in stratification matrix. 0 = Producitve Area, 1= No of departments, 2 = Biggest department area' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratification', @level2type=N'COLUMN',@level2name=N'ValueColumnIndex';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'If frozen, (true or 1) then the Stratification cannot be altered' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratification', @level2type=N'COLUMN',@level2name=N'Frozen';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratification]  WITH NOCHECK ADD  CONSTRAINT [FK_Stratification_StandRegister] FOREIGN KEY([StandRegisterId])&lt;br /&gt;
		REFERENCES [dbo].[StandRegister] ([StandRegisterId]);&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratification] NOCHECK CONSTRAINT [FK_Stratification_StandRegister];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratification] ADD  CONSTRAINT [DF_Stratification_StandRegisterId]  DEFAULT ((-1)) FOR [StandRegisterId];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratification] ADD  CONSTRAINT [DF_Stratification_ValueColumnIndex]  DEFAULT ((0)) FOR [ValueColumnIndex];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
	-- Create StratificationInterval table&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.StratificationInterval','U') IS NULL&lt;br /&gt;
	BEGIN&lt;br /&gt;
&lt;br /&gt;
		SET ANSI_PADDING ON;&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[StratificationInterval](&lt;br /&gt;
			[IntervalId] [int] NOT NULL,&lt;br /&gt;
			[StratificationGuid] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[TableName] [varchar](150) NULL,&lt;br /&gt;
			[ColumnName] [varchar](150) NULL,&lt;br /&gt;
			[Size] [int] NULL,&lt;br /&gt;
			[NumberOfSteps] [int] NULL,&lt;br /&gt;
		 CONSTRAINT [PK_StratificationInterval] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[IntervalId] ASC,&lt;br /&gt;
			[StratificationGuid] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		SET ANSI_PADDING OFF;&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'0 is row interval, 1 is column interval' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'StratificationInterval', @level2type=N'COLUMN',@level2name=N'IntervalId';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratificationInterval]  WITH CHECK ADD  CONSTRAINT [FK_StratificationInterval_Stratification] FOREIGN KEY([StratificationGuid])&lt;br /&gt;
		REFERENCES [dbo].[Stratification] ([StratificationGUID])&lt;br /&gt;
		ON DELETE CASCADE;&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratificationInterval] CHECK CONSTRAINT [FK_StratificationInterval_Stratification];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- Create Stratum table&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.Stratum','U') IS NULL&lt;br /&gt;
	BEGIN&lt;br /&gt;
&lt;br /&gt;
		SET ANSI_PADDING ON;&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[Stratum](&lt;br /&gt;
			[StratumGUID] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[Description] [varchar](200) NULL,&lt;br /&gt;
			[StratumLevel] [int] NOT NULL,&lt;br /&gt;
			[Color] [int] NULL,&lt;br /&gt;
			[SelectedDepartmentCount] [int] NULL,&lt;br /&gt;
			[ParentStratumGUID] [uniqueidentifier] NULL,&lt;br /&gt;
			[StratificationGUID] [uniqueidentifier] NOT NULL,&lt;br /&gt;
		 CONSTRAINT [PK_Strata] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[StratumGUID] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		SET ANSI_PADDING OFF;&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Level in hierarchy' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratum', @level2type=N'COLUMN',@level2name=N'StratumLevel';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'The number of departments that area going to be selectd from this Stratum' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratum', @level2type=N'COLUMN',@level2name=N'SelectedDepartmentCount';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'A Stratum can contain 1-M Stratums' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratum', @level2type=N'COLUMN',@level2name=N'ParentStratumGUID';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'a Stratum belong to a Stratification' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratum', @level2type=N'COLUMN',@level2name=N'StratificationGUID';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'A Stratum is a container for trees in a standregister' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratum';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratum]  WITH NOCHECK ADD  CONSTRAINT [FK_Strata_Strata] FOREIGN KEY([ParentStratumGUID])&lt;br /&gt;
		REFERENCES [dbo].[Stratum] ([StratumGUID]);&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratum] CHECK CONSTRAINT [FK_Strata_Strata];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratum]  WITH CHECK ADD  CONSTRAINT [FK_Strata_Stratification] FOREIGN KEY([StratificationGUID])&lt;br /&gt;
		REFERENCES [dbo].[Stratification] ([StratificationGUID])&lt;br /&gt;
		ON DELETE CASCADE;&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratum] CHECK CONSTRAINT [FK_Strata_Stratification];&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'1 Strata belong to 1 Stratification. 1 Stratification has 1-M Strata' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Stratum', @level2type=N'CONSTRAINT',@level2name=N'FK_Strata_Stratification';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[Stratum] ADD  CONSTRAINT [DF_Stratum_SelectedDepartmentCount]  DEFAULT ((0)) FOR [SelectedDepartmentCount];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- Create StratumCondition&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.StratumCondition','U') IS NULL&lt;br /&gt;
	BEGIN&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[StratumCondition](&lt;br /&gt;
			[StratumConditionGuid] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[RowNo] [int] NULL,&lt;br /&gt;
			[ColumnNo] [int] NULL,&lt;br /&gt;
			[StratificationGuid] [uniqueidentifier] NULL,&lt;br /&gt;
		 CONSTRAINT [PK_StratumCondition] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[StratumConditionGuid] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Row no in matrix' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'StratumCondition', @level2type=N'COLUMN',@level2name=N'RowNo';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Column no.position in matrix' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'StratumCondition', @level2type=N'COLUMN',@level2name=N'ColumnNo';&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Contains criteria specification for a tree to fall into a Stratum. E.g. a StratumCondition can be: Volume 200-400 m3  AND Age 60-70 year' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'StratumCondition';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumCondition]  WITH CHECK ADD  CONSTRAINT [FK_StratumCondition_Stratification] FOREIGN KEY([StratificationGuid])&lt;br /&gt;
		REFERENCES [dbo].[Stratification] ([StratificationGUID])&lt;br /&gt;
		ON DELETE CASCADE;&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumCondition] CHECK CONSTRAINT [FK_StratumCondition_Stratification];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumCondition] ADD  CONSTRAINT [DF_StratumCondition_RowNo]  DEFAULT ((-1)) FOR [RowNo];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumCondition] ADD  CONSTRAINT [DF_StratumCondition_ColumnNo]  DEFAULT ((-1)) FOR [ColumnNo];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- Create StratumConditionDetail&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.StratumConditionDetail','U') IS NULL&lt;br /&gt;
	BEGIN&lt;br /&gt;
&lt;br /&gt;
		SET ANSI_PADDING ON;&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[StratumConditionDetail](&lt;br /&gt;
			[StratumConditionDetailGUID] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[StratumConditionGuid] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[Variable] [varchar](150) NULL,&lt;br /&gt;
			[Operator] [varchar](50) NULL,&lt;br /&gt;
			[LeftValue] [float] NULL,&lt;br /&gt;
			[RightValue] [float] NULL,&lt;br /&gt;
			[StringValue] [varchar](150) NULL,&lt;br /&gt;
		 CONSTRAINT [PK_StratumConditionDetail_1] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[StratumConditionDetailGUID] ASC,&lt;br /&gt;
			[StratumConditionGuid] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		SET ANSI_PADDING OFF;&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'A Condition: E.g. Age between 60-70' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'StratumConditionDetail';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionDetail]  WITH CHECK ADD  CONSTRAINT [FK_StratumConditionDetail_StratumCondition] FOREIGN KEY([StratumConditionGuid])&lt;br /&gt;
		REFERENCES [dbo].[StratumCondition] ([StratumConditionGuid])&lt;br /&gt;
		ON DELETE CASCADE;&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionDetail] CHECK CONSTRAINT [FK_StratumConditionDetail_StratumCondition];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- Create StratumConditionDetalValue&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.StratumConditionDetailValue','U') IS NULL&lt;br /&gt;
	BEGIN&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[StratumConditionDetailValue](&lt;br /&gt;
			[StratumConditionDetailGuid] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[DoubleValue] [float] NOT NULL,&lt;br /&gt;
			[StratumConditionGuid] [uniqueidentifier] NULL,&lt;br /&gt;
		 CONSTRAINT [PK_StratumConditionDetailValue] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[StratumConditionDetailGuid] ASC,&lt;br /&gt;
			[DoubleValue] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Contains a list of values for a StratumConditionDetailRow' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'StratumConditionDetailValue', @level2type=N'COLUMN',@level2name=N'StratumConditionDetailGuid';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionDetailValue]  WITH CHECK ADD  CONSTRAINT [FK_StratumConditionDetailValue_StratumConditionDetailValue] FOREIGN KEY([StratumConditionDetailGuid], [StratumConditionGuid])&lt;br /&gt;
		REFERENCES [dbo].[StratumConditionDetail] ([StratumConditionDetailGUID], [StratumConditionGuid])&lt;br /&gt;
		ON DELETE CASCADE;&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionDetailValue] CHECK CONSTRAINT [FK_StratumConditionDetailValue_StratumConditionDetailValue];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- Create StratumConditionJunction&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.StratumConditionJunction','U') IS NULL&lt;br /&gt;
	BEGIN&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[StratumConditionJunction](&lt;br /&gt;
			[StratumGuid] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[StratumConditionGuid] [uniqueidentifier] NOT NULL,&lt;br /&gt;
		 CONSTRAINT [PK_StratumConditionJunction] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[StratumGuid] ASC,&lt;br /&gt;
			[StratumConditionGuid] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'Junction table between Stratum and StratumCondition tables' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'StratumConditionJunction';&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionJunction]  WITH CHECK ADD  CONSTRAINT [FK_StratumConditionJunction_Stratum] FOREIGN KEY([StratumGuid])&lt;br /&gt;
		REFERENCES [dbo].[Stratum] ([StratumGUID])&lt;br /&gt;
		ON DELETE CASCADE;&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionJunction] CHECK CONSTRAINT [FK_StratumConditionJunction_Stratum];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionJunction]  WITH CHECK ADD  CONSTRAINT [FK_StratumConditionJunction_StratumCondition] FOREIGN KEY([StratumConditionGuid])&lt;br /&gt;
		REFERENCES [dbo].[StratumCondition] ([StratumConditionGuid]);&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumConditionJunction] CHECK CONSTRAINT [FK_StratumConditionJunction_StratumCondition];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- StratumStandObjectJunction&lt;br /&gt;
&lt;br /&gt;
	IF OBJECT_ID ('dbo.StratumStandObjectJunction','U') IS NULL&lt;br /&gt;
		BEGIN&lt;br /&gt;
&lt;br /&gt;
		CREATE TABLE [dbo].[StratumStandObjectJunction](&lt;br /&gt;
			[StandObjectGUID] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[StratumGUID] [uniqueidentifier] NOT NULL,&lt;br /&gt;
			[RepresentativeArea] [float] NULL,&lt;br /&gt;
			[ProductiveArea] [float] NULL,&lt;br /&gt;
		 CONSTRAINT [PK_StratumStandObjectJunction] PRIMARY KEY CLUSTERED &lt;br /&gt;
		(&lt;br /&gt;
			[StandObjectGUID] ASC,&lt;br /&gt;
			[StratumGUID] ASC&lt;br /&gt;
		)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]&lt;br /&gt;
		) ON [PRIMARY];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumStandObjectJunction]  WITH CHECK ADD  CONSTRAINT [FK_StratumStandObjectJunction_StandObject] FOREIGN KEY([StandObjectGUID])&lt;br /&gt;
		REFERENCES [dbo].[StandObject] ([StandObjectGuid]);&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumStandObjectJunction] CHECK CONSTRAINT [FK_StratumStandObjectJunction_StandObject];&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumStandObjectJunction]  WITH CHECK ADD  CONSTRAINT [FK_StratumStandObjectJunction_Stratum] FOREIGN KEY([StratumGUID])&lt;br /&gt;
		REFERENCES [dbo].[Stratum] ([StratumGUID])&lt;br /&gt;
		ON DELETE CASCADE;&lt;br /&gt;
&lt;br /&gt;
		ALTER TABLE [dbo].[StratumStandObjectJunction] CHECK CONSTRAINT [FK_StratumStandObjectJunction_Stratum];&lt;br /&gt;
&lt;br /&gt;
	END&lt;br /&gt;
&lt;br /&gt;
	-- Update Version Table&lt;br /&gt;
&lt;br /&gt;
	UPDATE Version SET ApplicationVersion = '0.5.1.0';&lt;br /&gt;
&lt;br /&gt;
	PRINT 'Success! Database upgrade to version 0.5.1.0';&lt;br /&gt;
&lt;br /&gt;
END&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Category:Database]]&lt;/div&gt;</summary>
		<author><name>Cawa2</name></author>
	</entry>
</feed>