I am performing a comparison of the data on tables with a hierarchyId column as the primary key, but SQL Data compare is unable to match any row based on the value of the primary key, so, after the comparison has finished, all rows with the same primary key in both tables are displayed as existing both in source only and in target only. Is this a bug? I am using SQL Data Compare 14.5
Thanks in advance
data:image/s3,"s3://crabby-images/6ec72/6ec721116ee3c16de4e91a8aa8568a5c6126044e" alt="Image: /hc/user_images/01JKDFD0NGS9X3TA87AE4NY1Q8.jpeg"
data:image/s3,"s3://crabby-images/b4303/b4303edb17b879e3d0afdd97c6220307f26108ac" alt="Image: /hc/user_images/01JKDFD0Z8AM5R2494Z73ASRHQ.jpeg"
Comments
3 comments
-
Hi and thanks for your post @myoldhouse!
Just to confirm, is LocationID the primary key?
Are you able to share the CREATE scripts for the tables in both source and target?
Can you also please double-click on a few LocationID values in both the source and target to see the "Value Details" window and send a screenshot of what's shown for both? (I'm curious if the Value details view may shed some light on what SQL Data Compare finds different. )
-
Hi JessicaThanks for your attention. Regarding your questions:Yes, LocationID is the primary key of this table.Create script for source table :SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Locations](
[LocationID] [hierarchyid] NOT NULL,
[LocationHierarchyLevel] AS ([LocationID].[GetLevel]()) PERSISTED,
[LocationType] [tinyint] NOT NULL,
[LocationSubtype] [tinyint] NULL,
[LocationDescription] [varchar](25) NOT NULL,
[Classification] [int] NULL,
[Active] [bit] NOT NULL,
[PropagateActivationSettings] [bit] NOT NULL,
[OrderBy] [smallint] NOT NULL,
[ImageCollectionID] [int] NULL,
[GeographicData] [geography] NULL,
[ConcurrencyCheck] [timestamp] NOT NULL,
CONSTRAINT [PK_Locations] PRIMARY KEY CLUSTERED
(
[LocationID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY],
CONSTRAINT [IX_Locations_Type] UNIQUE NONCLUSTERED
(
[LocationID] ASC,
[LocationType] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
Create script for target table :SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Locations](
[LocationID] [hierarchyid] NOT NULL,
[LocationHierarchyLevel] AS ([LocationID].[GetLevel]()) PERSISTED,
[LocationType] [tinyint] NOT NULL,
[LocationSubtype] [tinyint] NULL,
[LocationDescription] [varchar](25) NOT NULL,
[Classification] [int] NULL,
[Active] [bit] NOT NULL,
[PropagateActivationSettings] [bit] NOT NULL,
[OrderBy] [smallint] NOT NULL,
[ImageCollectionID] [int] NULL,
[GeographicData] [geography] NULL,
[ConcurrencyCheck] [timestamp] NOT NULL,
CONSTRAINT [PK_Locations] PRIMARY KEY CLUSTERED
(
[LocationID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY],
CONSTRAINT [IX_Locations_Type] UNIQUE NONCLUSTERED
(
[LocationID] ASC,
[LocationType] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GOScreenshots with Value Details for records with id '/5/2/' in both tables. As you can see, SQL Data Compare is not matching these records but both have the same id:I performed a comparison using the following queries in Sql server management studio:SELECT COUNT(*) FROM caromil_v2_prod.dbo.locations [source] LEFT JOIN
caromil_v2dev.dbo.Locations [target] ON [source].locationId = [target].LocationID
WHERE [target].LocationID IS NULL
SELECT COUNT(*) FROM caromil_v2_prod.dbo.locations [source] RIGHT JOIN
caromil_v2dev.dbo.Locations [target] ON [source].locationId = [target].LocationID
WHERE [source].LocationID IS NULL
SELECT COUNT(*) FROM caromil_v2_prod.dbo.locations [source] INNER JOIN
caromil_v2dev.dbo.Locations [target] ON [source].locationId = [target].LocationID WHERE [source].Classification <> [target].Classification
SELECT COUNT(*) FROM caromil_v2_prod.dbo.locations [source] INNER JOIN
caromil_v2dev.dbo.Locations [target] ON [source].locationId = [target].LocationID WHERE [source].Classification = [target].ClassificationObtaining the following results:Only in source (query 1):172Only in target (query 2):1In both but different:2Identical:418Running the comparison with SQL Data Compare, the result is the following:Only in source (query 1):920Only in target (query 2):749In both but different:3Identical:440I will really appreciate your help.
-
Thank you!
I haven't been able to reproduce this yet, unfortunately. Can you please send a screenshot of how you have the comparison key set for the Location table? (From Edit Project>Tables and Views)
And I don't think this is contributing to the issue as I don't see any whitespace highlighted, but can you just confirm for me if enabling "Trim trailing whitespace" comparison option has any effect? Thank you!
Add comment
Please sign in to leave a comment.