-
Notifications
You must be signed in to change notification settings - Fork 24
Map private or protected properties #466
Comments
In your code example, you could just do this:
Enum integer values get mapped to int values in the database, you don't need to manually convert to/from an int to the Enum value - see Data Type Mapping in the wiki. |
Yes I understand, but that was only a abstract example, there are often cases where you want to hide the exact datafield in private scope to let manipulate only part of it or just not give the access to it. Let say you have a bitmask saved in an integer field. In code you would check this by boolean properties that inner access the bits. |
Even if you look at the example with the enum value. If an enum value is loaded that is not defined in code but a valid value, after loading it and updating it to the db, the value is overwritten with the default value. That is not what you want in this case. You would want to save the original integer value even if your code doesn't know it. |
The only suggestion I have for you based upon the current capability in MicroLite is to have a data object which maps to your database and then either have a business object or view model which receives the data object via its constructor to allow you to do what you want as far as encapsulation goes. There are some changes around mapping planned for MicroLite 7.0 which I'll be working on in the next few months which may offer you other alternatives. |
Yes, that's the way I do it now, I am working with a wrapper class. Thought there could be an easier way. Thanks for the reply. Do you have some kind of road map for the version 7? Curious to see what's on the way. |
Have a look at the blog, I posted something a while ago, there's also the milestone in the issues page |
It is often so,that you want to load something from the database but you want to handle it only in the class. Maybe some basic calculations or a certain way for handling with nummeric enum values that don't exist.
In this case you would use a public property that works with the private or protected field. From outside the class the db field does not have to be changed directly.
For example:
I this case you are forced to make everthing public although you don't want to make it accessable directly.
I mean there could be a configuration parameter to enable private mapping or maybe protected mapping.
The text was updated successfully, but these errors were encountered: