Initial values and Default Database values
No edit summary
Line 27: Line 27:
Controls both the in-memory nullability and database attribute setting.  
Controls both the in-memory nullability and database attribute setting.  


'''Please note!''' If this is '''false''', most database engines require a DefaultDbValue to evolve the database. If no value is provided, the existing rows (objects) in database will get an invalid value and the evolve will fail.
'''Please note!''' If this is '''false''', most database engines require a DefaultDbValue to evolve the database. If no value is provided, the existing rows (objects) in database would get an invalid value and the evolve will fail.


==== More detailed explanation on database creation and evolve ====
==== More detailed explanation on database creation and evolve ====

Revision as of 17:01, 16 January 2024

Property inspector for an modelled attribute

InitalValuesInPropertinspectorForAttribute.png

DefaultDbValue

The value used when evolving the database or creating the database. If the attribute is nullable, i.e. has Allow Null = true, the DefaultDbValue is not needed

This value should be in the format expected by the database engine.

Examples using SQL Server;

  • Non-nullable Decimal: 0
  • String: 'stringvalue' (quoted) (note: strings are always nullable if not using very old database types as char)

Initial value

Initial value used in-memory. Should be a value depending on type of attribute, or nothing/empty for null (if nullable).

Examples;

  • Non-nullable Boolean: false or true
  • Non-nullable Decimal: 0
  • String: stringvalue (no quotes)

Allow Null

Controls both the in-memory nullability and database attribute setting.

Please note! If this is false, most database engines require a DefaultDbValue to evolve the database. If no value is provided, the existing rows (objects) in database would get an invalid value and the evolve will fail.

More detailed explanation on database creation and evolve

Why is the DefaultDbValue needed to even add a non-nullable attribute to the database?

When evolving a database adding an attribute, the database needs to know what to do with existing rows (i.e. objects). This requires the field to be added with this initial value setting set before evolve. If your table table is empty, for example SQL Server will allow the evolve to go through, but you will not be able to add this setting without first dropping the attribute again (see below).

What if I forget to set nullability to false, and have already added the attribute to my model and evolved?

If you have the field already, but don't need the data, you can rename the field back and forth evolving after each renaming. First drop the attribute/field from the DB and then add it back with the right initial value.

This page was edited more than 9 months ago on 03/26/2024. What links here