-
-
Notifications
You must be signed in to change notification settings - Fork 709
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Group the Joins and Relations sections in a dedicated chapter #8435
Conversation
@ponceta ? |
I'm a great fan of this! 👍 @3nids do you think this is a good way to go? I got quickly over the builds artifacts and it looks good. https://github.com/qgis/QGIS-Documentation/actions/runs/5836463495 |
@3nids, may I? Thanks |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
good for me, some minor remarks
**Joins** allow you to associate features of the current layer | ||
to features from another loaded vector layer. | ||
Whether they are spatially enabled and their geometry type does not matter. | ||
The join is based on an attribute that is shared by the layers, in a one-to-one relationship. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it's not always one-to-one I believe. One-to-many is also possible.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Now that I read again, I think I wasn't clear enough. I was referring to joins in QGIS (rewording suggested above). Is that possible to have a one-to-many join in QGIS? Does QGIS not only perform a left join? I'd be curious for the how-to.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As I understand it, QGIS doesn't have a direct built-in one-to-many join operation for attribute tables. To achieve one-to-many relationship-like results, users need to use SQL queries or spatial databases. Therefore, there is no single workflow in QGIS for one-to-many joins. Consequently, I don't think one-to-many joins can be adequately described without external guidelines (such as PostgreSQL/PostGIS), and I'm not sure if that's something we want to include in QGIS documentation. @DelazJ, you may have more insight into the rules for external guidelines in QGIS docs.
Anyway, while I'm not an expert on spatial databases, I do know that Joins in QGIS allow relationships where features in one layer can be associated with features in another layer based on shared attributes. For instance, you could join a point layer representing cities to a table containing information about each city. Each city point can be associated with one record in the attribute table. Perhaps this is considered a one-to-many join, even if it's not a true one-to-many relationship in a relational database sense. In other words, is it possible that the terms 'one-to-one' and 'one-to-many' are misunderstood?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@selmaVH1 Thanks for the feedback and confirming that joins in layer properties only allow a feature to be associated to one other record.
Speaking of one-to-many relation, this is also possible in QGIS through the project relations but this is already addressed in the other part of the PR.
QGIS currently has support for joining non-spatial table formats supported by GDAL | ||
(e.g., CSV, DBF and Excel), delimited text and the PostgreSQL providers. | ||
|
||
.. is the above still true? No more supported formats (oracle, mssql, ...)??? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would have thought that this is available for any data source.
Setting relations between multiple layers | ||
========================================= | ||
|
||
Unlike joins that define a one-to-one link between features across two layers, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think this is the difference (as stated above, joins are not strictly 1-to-1). To me the main difference is that relation offers a mean to navigate through the relations, in other words list and discover features which are associated to each other.
|
||
You should enable the transaction mode in :menuselection:`Project Properties --> Data Sources -->` | ||
when working on such context. | ||
QGIS should be able to add or update row(s) in all tables (airlines, airports and the pivot tables). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
shall we suggest here to use UUIDs instead of increment?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry but I have no idea what you mean, @3nids
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@3nids I assume this refers to PostgreSQL, not QGIS?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @3nids for the feedback
I tried to reply and integrate your various comments (as suggestions for the moment instead of commits). I'm honestly quite unsure of the joins IN QGIS allowing one-to-many cardinality so if you can share some evidences, I will (be unhappy to have to) refactor the PR accordingly.
**Joins** allow you to associate features of the current layer | ||
to features from another loaded vector layer. | ||
Whether they are spatially enabled and their geometry type does not matter. | ||
The join is based on an attribute that is shared by the layers, in a one-to-one relationship. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Now that I read again, I think I wasn't clear enough. I was referring to joins in QGIS (rewording suggested above). Is that possible to have a one-to-many join in QGIS? Does QGIS not only perform a left join? I'd be curious for the how-to.
|
||
You should enable the transaction mode in :menuselection:`Project Properties --> Data Sources -->` | ||
when working on such context. | ||
QGIS should be able to add or update row(s) in all tables (airlines, airports and the pivot tables). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry but I have no idea what you mean, @3nids
Co-authored-by: Denis Rouzaud <denis.rouzaud@gmail.com>
c2f5f73
to
8fba947
Compare
Many many thanks to you! This is a great improvement for the understanding of relation management in QGIS! 👍 |
Supersedes #7563
The last section, about widgets and forms, is not in the PR. Not yet sure what existing sections to move there and how to structure it but the idea is to have most of the form widgets that handle relations and joins described also in this chapter.
Fixes #7558, fixes #6205, refs #7709
No plans to backport!