<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">@Richard: thanks for redirecting this question in to the correct people…and apologises for the size of the file…lack of specification on my part to a over enthusiastic team member ;-). I’ll reduce the size and put in a issue report.<br class=""><br class="">I’m in total agreement with you on the tremendous potential of GeoPackage to support the sharing of all types of data (statistical, geospatial, metadata, imagery…). Certainly the statistical community (the UNGGIM), is grappling with the issue of integrating statistical and geospatial data models and I think GeoPackage can provide one important part of the solution.<br class=""><br class="">As well as a useful container for publishing 2016 Census data...One of my aspiration is to use GeoPackage to publish the full data model that the ABS uses to internally store our geographic classification with the aim of providing a point of truth for all users.<br class=""><br class="">But to do both of these things well, views are very valuable and would prevent a lot of data duplication. <br class=""><br class="">@Even Thanks for the quick reply…and all your important support for GDAL.<br class=""><br class="">One of my team (more knowledgable than I) thought that it was an ID issue and both ESRI and Pitney Bowes seem to use a pseudo PKID to get around this issue (Pitney Bowes uses a specific field name MI_IDX)…so it good to have that confirmed. But it doesn’t look like there is a straight forward solution. Happy help going forward. We have scheduled September for development and testing, but I sure we can find some time before then.<br class=""><br class="">It interesting that, despite the lack of PKID, both the classification and symbolisation for a choropleth maps and the Identify Features Tool work as expected….thoughts?<br class=""><br class="">cheers,<br class=""><br class="">Marcus Blake<br class=""><br class="">——<br class="">Geospatial Data Manager<br class="">Australian Bureau of Statistics<br class=""><br class=""><br class=""><blockquote type="cite" class="">On 27 Jun 2016, at 6:10 AM, Even Rouault <<a href="mailto:even.rouault@spatialys.com" class="">even.rouault@spatialys.com</a>> wrote:<br class=""><br class="">Le dimanche 26 juin 2016 21:50:38, Richard Duivenvoorde a écrit :<br class=""><blockquote type="cite" class="">On 26-06-16 21:22, Even Rouault wrote:<br class=""><blockquote type="cite" class="">The issue is that the OGR GeoPackage driver cannot derive an integer<br class="">primary key from the view, and affects 0 as the fid for all features. In<br class="">the case of the views of this particular dataset, the OBJECTID field<br class="">could be used as the FID (given some logic to be implemented in the<br class="">driver to analyze the structure of the view, the underlying tables and<br class="">the unicity constraints on the join fields)<br class=""></blockquote><br class="">Ok... so, is this a driver challenge?<br class=""></blockquote><br class="">Eh, I love driver challenges :-)<br class=""><br class=""><blockquote type="cite" class=""><br class="">Or is it more an explicit problem, because the view is created without<br class="">explicit primary key?<br class=""><br class="">Because, instead of putting 'some logic' into the driver trying to guess<br class="">a primary key, we can maybe create some kind of PK-constraint?<br class=""><br class="">Like: a view (just like an Oracle table?) should have some kind of<br class="">primary key defined?<br class=""></blockquote><br class="">I'm not aware of a way of doing it :<br class=""><br class="">Here's a failed attempt :<br class="">sqlite> create unique index foo on sa1_b01_map_v ( OBJECTID );<br class="">Error: views may not be indexed<br class=""><br class="">I'd be curious if other databases have a way of doing it, but my feeling is <br class="">that I don't think it is possible for normal dynamic views. (Unless you are <br class="">using a materialized view as in Postgres for example)<br class=""><br class=""><br class=""><blockquote type="cite" class="">If not: ask for it, so it is defined into the view<br class="">definition (uh... not sure IF that is possible at all in a view...).<br class="">Or QGIS asks for it: showing the attributes, and letting the user choose<br class="">the id('s) that the user (thinks) are unique and should be used as<br class="">primary key...<br class=""></blockquote><br class="">That would be a possibility, although that would still require an enhancement <br class="">in the OGR side to accept the name of the PKID as an option.<br class=""><br class="">Anyway as a fallback in the absence of a PKID a sequential numbering would <br class="">probably be desirable (with the caveat that it wouldn't be stable when <br class="">attribute or spatial filters are applied, which could cause some problems )<br class=""><br class="">Even<br class=""><br class="">-- <br class="">Spatialys - Geospatial professional services<br class=""><a href="http://www.spatialys.com" class="">http://www.spatialys.com</a></blockquote></body></html>