Open bisen2 opened 3 years ago
Btw, I heavily recommend the type-safe
``Create(...)``(...)
over .Create()
Basically if you add a non-nullable field to the table, you want your error compile-time.
Wouldn't you still get compile time checking at newRow.ColumnN <- myRow.ColumnN
? If newRow.ColumnN
is an int
but myRow.ColumnN
is an Option<int>
there should be a compile-time error on that line.
Yes, but what if your database changes? You drop a column or add a new non-nullable one...
Ah that's a good point. Thanks for the pointers!
Is your feature request related to a problem? Please describe. This library provides the
.MapTo<'T>
to map an entity to a record type (which is awesome), but it is not as simple to map this record type back to an entity. Mapping back can be done manually, but it can get a little cumbersome when the entity has a lot of columns.Describe the solution you'd like It would be cool to have some sort of inverse of the
.MapTo<'T>
method that could take a record and return an entity.Describe alternatives you've considered As mentioned above, it can currently be done manually. This works fine for small entities, but scales with the number of columns in the entity.
Basic Example If we have a table
MyTable
with columnId
that is mapped by the recordMyTable_Row
, you can easily grab a row based on the columnId
usingThis method is independent of the number of columns in
MyTable
(other than in the definition ofMyTable_Row
). But, if we want to add a row toMyTable
from aMyTable_Row
, we need to manually specify that each column gets populated:With this, not only does the definition of the record type need to scale with the number of columns in the entity, but all functions performing inserts must too.