Database views and relationship classes

5265
9
08-03-2017 02:42 AM
Panagiotis
New Contributor II

Hi,

We have ArcGIS Desktop 10.5 Standard and ArcGIS Server 10.5 Standard running on Windows Server 2012R2 Standard with Microsoft SQL Server 2012 (SP1) running on Windows servers.

 

I am trying to figure out if I can create a relationship class in our enterprise geodatabase between a feature class and a view or between a spatial view and a view.

 

I already have created a relationship class between a feature class (land parcels) and a table (landowners), however I would like to join some additional information stored in lookup tables to each table in the form of views and have another relationship class between those two views (spatial view for land parcels and non-spatial view for landowners). So, for now I have created a view for the landowners (which I have registered with the entrprise geodatabase) and have tried to create a M-N relationship class between the land parcels feature class and that landowners view, but I am getting the following error message: "Create Relationship Class: Failed to create the specified relationship class. Not supported on a view."

Any help would be highly appreciated.

Thanks,

Panos

9 Replies
Asrujit_SenGupta
MVP Regular Contributor

Try Registering the View with Geodatabase and then create the Relationship Class:

Register a table or view with the geodatabase—ArcGIS Help | ArcGIS Desktop 

Note: Will suggest creating a test view and experimenting with that first, before trying with the actual one.

0 Kudos
Panagiotis
New Contributor II

Hi Asrujit,

Thanks for replying.

I have tried that already and I'm still getting the message below.

So, I have created a test non-spatial view for the landowners using the Create Database View tool. I have also registered that view with the enterprise gdb following the instructions at the link above. However, when I'm trying to create a M:N relationship class between the land parcels feature class and that view (they are both owned by the same enterprise gdb) either by right clicking and New > Relationship Class or by using the Create Rewlationship Class tool, I'm getting the message below after I click Finish/Ok.

Create Relationship Class error message

Is there something I'm missing here? Is this do-able at all or should I think of a workaround?

Cheers,

Panos

0 Kudos
Asrujit_SenGupta
MVP Regular Contributor

Considering the above, I feel its not do-able then.

Registering a table with the geodatabase allows the table to participate in geodatabase functionality, such as adding subtypes to it, defining domains for fields in the table, and placing the table in a relationship class. If it is a spatial table (a feature class), you can also move it into a feature dataset so it can be used in topologies, networks, terrains, and other feature dataset constructs.

Registering a view with the geodatabase allows the view to be included in read-only feature services.

Also the link that I provided, mentions the above. So it seems that Views cannot participate in a Relationship Class in any scenario.

MōnoSimeone
Occasional Contributor II

I did NOT have success with this. It appears that relationship classes cannot work with a view - which I have to believe is some technical limitation.

The table to relationship class tool works great for creating a many-to-many relationship when you have/want to manage an intermediate table between non-view objects.

0 Kudos
BradJones3
Occasional Contributor

I had this issue recently a 10.5 enterprise geodatabase and I called Esri tech support.  The analyst was perplexed that I have  existing relationships between spatial views and tables in a 10.2 enterprise geodatabase.  The analyst said this should not be the case; relationship classes are not supported with a view. 

I believe it comes down to how the views are created.  We were still using 10.2 because we could create a spatial views with the old ArcSDE command line tools.  With 10.5 you could register the view with a geoprocessing tool.  But in 10.5 we can't use the relationships with the views.  

The workaround was to use a python script (arcpy) every night to go from  spatial view --> to feature class then rebuild relationships.

MichaelVolz
Esteemed Contributor

I have a nightly arcpy script that truncates and appends data from 1 source location to a destination location where a relationship class exists, but I do not need to rebuild the relationship for the relates to function properly.  Just wondering if you really need to perform a nightly rebuild of the relationship after moving the data.

BradJones3
Occasional Contributor

I wouldn't need to if I truncate and append.  In mine I'm overwriting the existing feature class which requires me to rebuild the relationship.  If i have to do it again I might go with truncate and append, but right now it works.  

0 Kudos
AllanBenvin_yyc
New Contributor III

Just my two cents. Views can be registered with the geodatabase in 10.5.1 but it won't allow you to create relationship classes or put it in a feature dataset. However 10.2.2 can still be used to create a relationship class on a registered view.

0 Kudos
AdamBakiera
Occasional Contributor

Just checking in to see if relationship classes are supported for non-spatial views. We are running ArcMap Enterprise/Desktop 10.5.1.