Summary: | Kexi crashes while trying to save query with join on non PK fields | ||
---|---|---|---|
Product: | [Applications] KEXI | Reporter: | Werner Llacer <wllacer> |
Component: | Queries | Assignee: | Jarosław Staniek <staniek> |
Status: | CLOSED FIXED | ||
Severity: | major | CC: | dimitrios.tanis |
Priority: | NOR | ||
Version: | 2.4.0 | ||
Target Milestone: | --- | ||
Platform: | Arch Linux | ||
OS: | Linux | ||
Latest Commit: | http://commits.kde.org/calligra/85790700a0ab6cc15cea2dc9a09d23594f2f4ee4 | Version Fixed In: | |
Sentry Crash Report: | |||
Attachments: |
Sample database
DrKonqi trace of the error Corrected database schema |
Description
Werner Llacer
2012-04-15 18:00:13 UTC
Created attachment 70407 [details]
Sample database
Created attachment 70408 [details]
DrKonqi trace of the error
*** Bug 298294 has been marked as a duplicate of this bug. *** Created attachment 70545 [details]
Corrected database schema
Hi Werner. First of all thank you for your elaborate report. Providing a good report is essential so that we can solve issues as they come in. I could reproduce the crash with the samples you have provided. It is caused when you join fields that are not Primary Keys. For some reason this only happens when you Design the query > Switch to design view > Switch back to design View > Hit Save button. For a temporary workaround you could design your query in Design Mode > Save and then run the query. That is Save the query BEFORE you go to the Data View. Further more I would like to recommend you to take another look at your database schema. Having PKs and joining on other fields violates normalization rules and makes PKs redundant (With some exceptions). To better explain for the sample database you provided: Tables named codigos and codigos2 are lookup tables. That is they provide values that fields in other tables look up. These are defined OK and they have a incremental PK and other fields. The base table is where you have the problem. Fields Campo2 and Campo3 are lookup columns. That is columns that lookup data from other tables. To make your database design efficient in both these columns you would use Primary Key values from tables codigos and codigos2 and NOT values from other cells. That would make them Foreign Keys. Then when you design a query you would make a relationship between a PK (id from codigos) and a FK (Campo2 from Base). Please study the attached database named "Corrected database schema" and the table base_new to understand how the table should be constructed and then check the consulta2_new query to see how that works nicely now. At the table design please check the fields' comments and note that the real values in the table are PK values from tables codigos and codigos2. The data you want to see is set from the "Lookup column" tab (next to the properties tab). I hope you get the best out of Kexi. *** bug 298294 has been marked as a duplicate of this bug *** Thanks for the reply. I'm at the moment at sick bed and have just the time to check in. So i hope to give you a detailed reply next week. BTW: I've spent the last 20 something years going back and forth from DBA to sysmgr position on mainframe environments (DB2, Adabas on Z/OS or Oracle under Unix). Don't tell me about DB Design and weird necessities .. Werner, regardless the normalization rules, Kexi should work OK for the relation you specified, so we want to fix this bit of course. You provided my brand new scar its first good laugh. It did hurt. You had to pay for it ;-) Seriously, I really find it has been a sensible idea to provide the educative bit about lookup tables and foreing keys, virtually lingo-free (most desktop DB users i've met, don't have the slightest exposure to relational design). I might be not the target, but it is really a good idea Anyway, (per other bug i opened last week) you can only save a query once, so i will try to stick to the workaround (while very much against my normal usage) till you can fix it Why I'm using non keyed lookup tables, then? A bit of background -and self justifiying-is not out of place. The database i'm testing Kexi with is a third party data warehouse (detailed Spanish Municipal Elections Results from 2011 if you ever want to know), originally in MDB, and with a star schema, very odd on first sight. In a couple of the lookup tables the natural key is a list of fields, defining a fixed length hierachy, and lookup can be done on any level of the hierarchy. In such an scenario, significant primary keys are useless or even impossible:depending on value spread,the best design query-wise could be to nullify all component fields thus making a significant primary key inacceptable for any SQL database. It is asumed that no self respecting designer would accept a non significative value in a lookup field (exactly this is the difference with Data Model Relationship derived foreign keys). To have a real code in the record has saved many the day ... An intersting sample is Oracle's smart CG_REF_CODES table for Designer/Forms. A single table designed to hold lookup tables, including time constrained or intervals. The internal PK has absolutely nothing to do with the field value. Dear Werner, thanks for the explanation and the background. I propose to move such supervaluable discussion to http://forum.kde.org/viewforum.php?f=220 is that makes sense for you, so others can contribute their use cases. As an update: I think I am close to fixing this really not obvious bug (it really hurt in many other use cases, not just saving). Hi Werner. I'd like to apologize if I sounded too prickly. Many times users coming here have pretty much non existent knowledge of RDBMS and we try to put their efforts in creating a database to a good start. Providing the explanation really gives now a use case that represents a valid scenario and thus exposes a bug otherwise would not be given much attention at first (I bet you've seen bad db schemas yourself). Thank you for the report and keep them coming. :) Jaroslav. Of course you can move what you think interesting to the forum. I will register there ASAP. Is really good to hear you have the bug cornered so soon. Dimitrios. I thought it was me who was being too harsh ... It is really a pleasure to work for you both. Hi Werner, the bug is almost fixed now. It would appear in many unexpected cases. I expect to have solution this week. Git commit 8a00c61dbee111f1522d71e84541e5bf7a37221f by Jaroslaw Staniek. Committed on 03/05/2012 at 00:04. Pushed by staniek into branch 'kexi-features-staniek'. KexiDB: fix crashed when saving query design *put DESC/ASC after COLLATE section, not before (needed at least for sqlite driver) *fixed crash because of invalid deletion order of query structures *fixed crash because of invalid deletion relationship structures M +7 -0 kexi/doc/dev/CHANGELOG-Kexi-js M +22 -18 kexi/kexidb/queryschema.cpp M +1 -1 kexi/kexidb/relationship.h M +6 -1 kexi/plugins/queries/kexiquerydesignerguieditor.cpp http://commits.kde.org/calligra/8a00c61dbee111f1522d71e84541e5bf7a37221f Please test... Git commit 0fefd8dbbe333000ab27dcf91c345863a39751d9 by Jaroslaw Staniek. Committed on 03/05/2012 at 00:04. Pushed by staniek into branch 'master'. KexiDB: fix crashed when saving query design *put DESC/ASC after COLLATE section, not before (needed at least for sqlite driver) *fixed crash because of invalid deletion order of query structures *fixed crash because of invalid deletion relationship structures REVIEW:104833 M +7 -0 kexi/doc/dev/CHANGELOG-Kexi-js M +22 -18 kexi/kexidb/queryschema.cpp M +1 -1 kexi/kexidb/relationship.h M +6 -1 kexi/plugins/queries/kexiquerydesignerguieditor.cpp http://commits.kde.org/calligra/0fefd8dbbe333000ab27dcf91c345863a39751d9 Git commit 85790700a0ab6cc15cea2dc9a09d23594f2f4ee4 by Jaroslaw Staniek. Committed on 03/05/2012 at 00:04. Pushed by staniek into branch 'calligra/2.4'. KexiDB: fix crashes when saving query design *put DESC/ASC after COLLATE section, not before (needed at least for sqlite driver) *fixed crash because of invalid deletion order of query structures *fixed crash because of invalid deletion relationship structures REVIEW:104833 M +7 -0 kexi/doc/dev/CHANGELOG-Kexi-js M +22 -18 kexi/kexidb/queryschema.cpp M +1 -1 kexi/kexidb/relationship.h M +6 -1 kexi/plugins/queries/kexiquerydesignerguieditor.cpp http://commits.kde.org/calligra/85790700a0ab6cc15cea2dc9a09d23594f2f4ee4 Git commit 981708e44f67b64da98ca86e4982d2a2545a69b2 by Jaroslaw Staniek. Committed on 27/06/2012 at 13:05. Pushed by staniek into branch 'master'. Fix crashes when saving query design *(2012-05-03 calligra master commit 0fefd8dbbe33) M +19 -18 Predicate/QuerySchema.cpp M +1 -1 Predicate/Relationship.h http://commits.kde.org/predicate/981708e44f67b64da98ca86e4982d2a2545a69b2 |