-
Notifications
You must be signed in to change notification settings - Fork 601
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
AutoIncrement triggered by 0 value id. #1490
Comments
From SQLITE docs:
What use case would require you to use 0 as the id if its an autoincrementing column? You probably would want to use a regular non autoincrementing column in the DB for anything but ids that get autogenerated for you. |
We already warn you in the processor if you use a nullable type:
but dont explicitly forbid it, especially if you want to use null for objects that you will fill with real value prior to saving to DB. |
This was more about allowing the column (if marked auto-incrementing) to be seeded with data that contains a 0, sqlite does not forbid this. You are correct it does semantically default to a starting id of 1, which is fine in this scenario and probably the reason why DBFlow works this way (there isn't much choice). The use case for this is data sync, so say for example I import a table from a backend data service that has the id's pre-generated, but we also allow for additional rows to be added internally (using the auto-increment feature. The backend generated data can contain a valid primary key id that is zero, which would get inserted to the database in DBFlow as an auto incremented id (and not explicitly zero). This obviously causes issues when FK's are depending on the id of 0. I just figured it would be cleaner to allow for nulls, however it doesn't seem to be the case in DBFlow due to the hasAutoIncrement() method in ModelAdapter<>: -
I might be missing something as I am a newbie with DBFlow but I couldn't get it to work due to the method above. I didn't use any annotations, and just to clarify I am using Kotlin which the preprocessor warning you pointed out says simply 'don't make it nullable' ;) To be honest with you, to work around this we simply managed the id's internally and don't use the auto-increment feature at this stage, however if DBFlow were to allow using "null" as the flag as opposed to "0", this might be a better approach as at the sql level, primary keys are typically by definition not-null. This might be something to think about supporting formally with the shift to Kotlin. |
I see so something like this: public boolean hasAutoIncrement(TModel model) {
Number id = getAutoIncrementingId(model);
return id != null && id.longValue() > 0;
} would be beneficial? I think that makes sense. |
so when its null we treat it also as if its missing |
in |
Awesome thanks! :) |
DBFlow Version: 4.1.2
Issue Kind (Bug, Question, Feature): Question
Description:
Regarding auto increment support, I noticed that you are using '0' as a signifier for triggering an object's id column to increment automatically. If the id value is predefined in the model/object it must be > 0 to prevent the incrementation.
This behaviour seems to be defined specifically in the ModelAdapter<> in the method "hasAutoIncrement" which might be better called something like "requiresAutoIncrement" with the logic negated, as it is really determining if the column is not predefined and needs to be be auto incremented. I also noticed the method treats null with an exception, which leads me to my question...
What do you think about changing this behaviour so that (rather than 0) if you (optionally?) autoincremented this based on the id being null? The point is that zero is technically a valid "predefined" id, and my particular use case actually requires this. I discovered this after finding that all predefined rows that I insert (for data sync) which contain a preset id of '0' got autoincremented, unexpectedly.
I think this might be better handled as you transition the codebase to Kotlin as you should be able to better detect whether or not the id type is Int? or Int. But it could be addressed either way via annotations...
Just curious what your thoughts are regarding this, and if my understanding is in error. I am happy to help contribute a solution if you agree.
Thanks in advance! What a great library this is :)
The text was updated successfully, but these errors were encountered: