[Qgis-user] QGIS behavior for DB table with single general geometry column vs table with multiple specific geometry columns
Richard Duivenvoorde
rdmailings at duif.net
Wed Nov 30 00:25:07 PST 2022
Hi Johannes,
A good idea, which I think is not yet implemented in browser, for what I know.
I know that there has been some funding on moving DB Manager functionality to the browser. So browser/database function getting better and better with every QGIS version.
Not sure if this would be an idea for a next funding round?
Regards,
Richard Duivenvoorde
On 11/28/22 14:39, Johannes Echterhoff via Qgis-user wrote:
> Hi all,
>
> This topic may have come up before, in which case I apologize up-front. I just want to make sure that I am not missing anything.
>
> My question is about the behavior in QGIS for a database table, let's call it "ft_geometry", with a single, general geometry column (geometry type is GEOMETRY), compared to the behavior of a table "ft_multi" which has multiple columns with a specific geometry type (for example, one column with MULTIPOINT and one with MULTILINESTRING). When I connect to such a database - e.g., a PostgreSQL one - and open it in the project browser, then ft_geometry is not shown at all, while ft_multi is shown as many times as there are columns with specific geometry type.
>
> QGIS allows adding ft_geometry manually, thereby choosing a specific geometry type for editing, via the Data Source Manager and via the DB Manager. I'll explain that using an example database schema and QGIS screenshots in more detail below, just for reference. However, what I am wondering is: Is it possible to somehow achieve, that, when opening the database in the project browser, ft_geometry is also shown with a list of specific geometry types (e.g., point and line)? Is there maybe a configuration option where one could set the desired specific geometry types, to be used in such a scenario, or a plugin? I've scanned the list of available plugins in QGIS 3.28.0, without success - but I may very well have missed something there. The background of why I'd like to have a certain list of specific geometry types is that in my use case, objects represented by tables like ft_geometry always have the same list of specific geometry types - and there can be many such tables in the
> database, which is why I am searching for a way to avoid manually adding such tables (each as many times as the specific geometry types that are needed).
>
> Any help or guidance would be very appreciated.
>
> Best regards,
>
> Johannes
>
> P.S.: Here is the database schema as well as QGIS screenshots
>
> ------
>
> CREATE EXTENSION postgis;
>
> CREATE TABLE ft_geometry (
>
> _id bigserial NOT NULL PRIMARY KEY,
>
> name text,
>
> position geometry(GEOMETRY,25832)
>
> );
>
> CREATE TABLE ft_multi (
>
> _id bigserial NOT NULL PRIMARY KEY,
>
> name text,
>
> position_point geometry(MULTIPOINT,25832),
>
> position_line geometry(MULTILINESTRING,25832),
>
> position_polygon geometry(MULTIPOLYGON,25832)
>
> );
>
> CREATE INDEX idx_ft_geometry_position ON ft_geometry USING GIST (position);
>
> CREATE INDEX idx_ft_multi_position_point ON ft_multi USING GIST (position_point);
>
> CREATE INDEX idx_ft_multi_position_line ON ft_multi USING GIST (position_line);
>
> CREATE INDEX idx_ft_multi_position_polygon ON ft_multi USING GIST (position_polygon);
>
> ------
>
> My test project, in which I've connected to the "test_geometry" database; table ft_geometry is not shown in the project browser ("Also list tables with no geometry" is enabled in the connection settings, as is "Don't resolve type of unrestricted columns (GEOMETRY)"); table ft_multi is shown three times:
>
> One can add ft_geometry via the Data Source Manager, by manually selecting the spatial type:
>
> Another way to add ft_geometry is via the DB Manager; here is the view of ft_geometry in the DB Manager:
>
> And here is the view in the DB Manager for ft_multi (just in case):
>
> By selecting ft_geometry in the DB Manager view of database test_geometry, then right-clicking, the dialog with the option to "Add Layer (Advanced)..." opens:
>
> There, one can choose the specific geometry type - as well as CRS (which should be chosen to match the one defined in the column geometry definition):
>
>
> _______________________________________________
> Qgis-user mailing list
> Qgis-user at lists.osgeo.org
> List info: https://lists.osgeo.org/mailman/listinfo/qgis-user
> Unsubscribe: https://lists.osgeo.org/mailman/listinfo/qgis-user
More information about the Qgis-user
mailing list