Skip to content
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

Virtual layers (nested), all layers disappear from project file (.qgs) when the project is saved #25681

Closed
qgib opened this issue Jan 4, 2018 · 6 comments
Labels
Bug Either a bug report, or a bug fix. Let's hope for the latter! Crash/Data Corruption Data Provider Related to specific vector, raster or mesh data providers

Comments

@qgib
Copy link
Contributor

qgib commented Jan 4, 2018

Author Name: Christian Nielsen (Christian Nielsen)
Original Redmine Issue: 17785
Affected QGIS version: 2.18.2
Redmine category:virtual_layers


When using nested virtual all layers disappear from project file (.qgs) when the project is saved, if not the individual virtual layers have been manually updated.

Example:

layer_1: SELECT * FROM point_file WHERE point_id = 1
layer_2: SELECT st_buffer(geometry,100000) FROM layer_1

If I change the point_id referenced in the WHERE clause for layer_1, I need to edit the layer_2 expression again (without any changes) for it to update. And if I save and close the project without doing that manual update, when i re-open later the project file will be corrupted and all layers will be missing from the project (including regular vectors/rasters).

/Christian

@qgib
Copy link
Contributor Author

qgib commented Jan 5, 2018

Author Name: Jakob Lanstorp (Jakob Lanstorp)


I can confirm this issue in QGIS 2.18.15. There should be an automatically or cascading update on virtual layers depending on each other. In the mean time you can condense you query to one virtual layer with a commen table expression (with clause).

@with pointid1 as
(
select geometry from point_file where id = 1
)
select st_buffer(geometry, 10) from pointid1;@

or just add a point_id where clause to layer_2

@qgib
Copy link
Contributor Author

qgib commented Jan 8, 2018

Author Name: Christian Nielsen (Christian Nielsen)


Thanks, I'll look into your suggested workaround in the meantime.

/Christian

Jakob Lanstorp wrote:

I can confirm this issue in QGIS 2.18.15. There should be an automatically or cascading update on virtual layers depending on each other. In the mean time you can condense you query to one virtual layer with a commen table expression (with clause).

@with pointid1 as
(
select geometry from point_file where id = 1
)
select st_buffer(geometry, 10) from pointid1;@

or just add a point_id where clause to layer_2

@qgib
Copy link
Contributor Author

qgib commented Feb 22, 2018

Author Name: Giovanni Manghi (@gioman)


  • priority_id was changed from Normal to High

@qgib
Copy link
Contributor Author

qgib commented Oct 23, 2018

Author Name: Regis Haubourg (@haubourg)


Trying to replicate here.

If I change the point_id referenced in the WHERE clause for layer_1, I need to edit the layer_2 expression again (without any changes) for it to update

Can you explain more precisely how you change the point_id reference ? Manually in the Qgs?
Saving cascaded virtual layers in qgs file works here, in 2.18.21 and latest master 3.3. I just don't get how you try to change the definition of layer_1.
And I agree that embedding sub-queries directly is more elegant and less risky.


  • status_id was changed from Open to Feedback
  • priority_id was changed from High to Normal

@qgib
Copy link
Contributor Author

qgib commented Jan 20, 2019

Author Name: Jürgen Fischer (@jef-n)


Please test with QGIS 3.4 - QGIS 2.18 reached it's end of life.

@qgib
Copy link
Contributor Author

qgib commented Mar 9, 2019

Author Name: Giovanni Manghi (@gioman)


End of life notice: QGIS 2.18 LTR

Source:
http://blog.qgis.org/2019/03/09/end-of-life-notice-qgis-2-18-ltr/

QGIS 3.4 has recently become our new Long Term Release (LTR) version. This is a major step in our history – a long term release version based on the massive updates, library upgrades and improvements that we carried out in the course of the 2.x to 3x upgrade cycle.

We strongly encourage all users who are currently using QGIS 2.18 LTR as their preferred QGIS release to migrate to QGIS 3.4. This new LTR version will receive regular bugfixes for at least one year. It also includes hundreds of new functions, usability improvements, bugfixes, and other goodies. See the relevant changelogs for a good sampling of all the new features that have gone into version 3.4

Most plugins have been either migrated or incorporated into the core QGIS code base.

We strongly discourage the continued use of QGIS 2.18 LTR as it is now officially unsupported, which means we’ll not provide any bug fix releases for it.

You should also note that we intend to close all bug tickets referring to the now obsolete LTR version. Original reporters will receive a notification of the ticket closure and are encouraged to check whether the issue persists in the new LTR, in which case they should reopen the ticket.

If you would like to better understand the QGIS release roadmap, check out our roadmap page! It outlines the schedule for upcoming releases and will help you plan your deployment of QGIS into an operational environment.

The development of QGIS 3.4 LTR has been made possible by the work of hundreds of volunteers, by the investments of companies, professionals, and administrations, and by continuous donations and financial support from many of you. We sincerely thank you all and encourage you to collaborate and support the project even more, for the long term improvement and sustainability of the QGIS project.


  • resolution was changed from to end of life
  • status_id was changed from Feedback to Closed

@qgib qgib closed this as completed Mar 9, 2019
@qgib qgib added Bug Either a bug report, or a bug fix. Let's hope for the latter! Data Provider Related to specific vector, raster or mesh data providers Crash/Data Corruption labels May 25, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Either a bug report, or a bug fix. Let's hope for the latter! Crash/Data Corruption Data Provider Related to specific vector, raster or mesh data providers
Projects
None yet
Development

No branches or pull requests

1 participant