codefluent

value from database computed property is Null in codefluent entity property


My MS SQL 2014 database table has a computed property column which uses a database function. Using SQL Server Management Studio, a query against the table lists the computed property values as expected.

The Codefluent model created via the import wizard shows the Entity with the computed column as a property. The underlying .cpf file defines the property with "d3p1:compute=" and the list of parameters that are used by the database function.

When an entity or the collection of entities is loaded, the properties which are used in the computed property have values, yet the computed property has a value of nothing/null.

How do I get Codefluent to read the computed value from the database table and have the value included in the entity's properties?


Solution

  • This is a bit tricky. First of all, you should declare the property like any other property. Then you must instruct the SQL producer to declare a formula on that column. You can do that with a custom 'compute' attribute in the SQL producer namespace. You can set it with the Visual Studio modeler like this:

    enter image description here

    In this example I've created an int property that is just another column value multiplied by 2.

    Optionally, you can declare the property to be 'read on save' because most of the time, you want to read the computed value after a save, not only on load operations:

    enter image description here

    Once this is all done, this sample console app should display 30:

    class Program
    {
        static void Main(string[] args)
        {
            var c = new Customer();
            c.Name = "killroy";
            c.Age = 15;
            c.Save();
            Console.WriteLine(c.Age2); // will display 30
        }
    }