Here is what I am doing, and not working for me.
I have a DAL generated with SubSonic 3 ActiveRecord template, I have a service layer (business layer if you well) that have mixture of facade and some validation.
Say I have a method on the Service layer like public void UpdateClient(Client client); in my GUI i create a Client object fill it with some data with ID and pass it to the service method and this never worked, the dirty columns collection (that track which columns are altered in order to use more efficient update statement) is always empty.
If I tried to get the object from database inside my GUI then pass it to the service method it's not working either.
The only scenario I find working is if I query the object from the database and call Update() on the same context all inside my GUI and this defeats the whole service layer I've created.
However for insert and delete everything working fine, I wonder if this have to do something with object tracking but what I know is SubSonic don't do that.
Please advice. thanks. Adel.
Instead of:
You can do:
This saves having to query the database server again.
For example:
It seems to be a feature and not a bug. Subsonic will only mark a column as dirty if the object is loaded from DB. So you can't really save and object, add changes to its properties and then save it again. Go figure.
See how the member variable _isLoaded is false unless the object really is loaded from DB. Subsonic never adds my property to the list of dirty columns.
Your repository Save() method would have to look something like this: