build-in support for dynamic schema

Posts   
 
    
alexkor88
User
Posts: 8
Joined: 06-Apr-2022
# Posted on: 06-Apr-2022 04:44:50   

I'm looking for dynamic schema for our new ERP application, which allow user to add new column or new table at runtime

I have study the backslash's solution & it is exactly what we want, but it need to alter the ORMSupportClasses -> https://www.llblgen.com/tinyforum/Thread/8232/1

I just wonder latest LLBLGen pro version have build-in support for dynamic schema Is it can support dynamic schema without alter the ORMSupportClasses?

We are using LLBLGen Pro version 5.8

Otis avatar
Otis
LLBLGen Pro Team
Posts: 39760
Joined: 17-Aug-2003
# Posted on: 06-Apr-2022 09:17:11   

Our system uses static/shared objects with persistence info for the entities. To make that dynamic, you have to supply these at runtime. While this is doable, there's not a simple-to-use API available. Additionally, the fields objects in the entities are precalculated. you have to provide these at runtime in a dynamic fashion too. This requires substantial refactoring of the runtime.

Frans Bouma | Lead developer LLBLGen Pro
alexkor88
User
Posts: 8
Joined: 06-Apr-2022
# Posted on: 11-Apr-2022 10:07:45   

Otis wrote:

Our system uses static/shared objects with persistence info for the entities. To make that dynamic, you have to supply these at runtime. While this is doable, there's not a simple-to-use API available. Additionally, the fields objects in the entities are precalculated. you have to provide these at runtime in a dynamic fashion too. This requires substantial refactoring of the runtime.

Thanks for prompt reply, Otis

Just need this info before we alter any classes. thanks

Otis avatar
Otis
LLBLGen Pro Team
Posts: 39760
Joined: 17-Aug-2003
# Posted on: 12-Apr-2022 09:18:30   

The info is provided at runtime by the ModelInfoProvider, which contains a FieldInfoProvider instance which contains all the field information data for the fields in an entity. The FieldInfoProvider also has precalculated objects for fields for an entity, so only the values are non-static. These have a fixed length (namely the length related to the # of fields in the entity).

To make that dynamic you have to make sure the FieldInfoprovider provides the right EntityFields(2) objects at runtime. I would only focus on Adapter. See e.g. FieldInfoProvider.cs, like 396 (public IEntityFields2 GetEntityFields(IInheritanceInfoProvider inheritanceProvider, string entityName)) how this works.

For your situation you have to make sure you provide the fields object using the dynamic size you want. That's one part.

Another other part is that for the entity itself it has to read/write from/to that object in the entity so you have to add your properties in some form the same way as the generated ones.

For generating queries, you have to make sure when you fetch entities of a given type, the DQE will produce a projection of all the fields in the projection. The information from that is from the PersistenceInfoProvider. This object (which is generated and an instance is available in the adapter) contains the mapping information for an entity and its fields. This has to be in sync with the fields in the field info provider, so a field at offset 3 in the EntityFields2 object has its persistence info also at offset 3 in the array with fieldpersistenceinfo's.

The PersistenceInfoProvider too uses precalculated static objects as it's readonly data. To dynamically change these, you have to make sure it works well in a multi-threaded environment. This is crucial as you'll otherwise run into issues and likely come here asking why things break and it'll be hard to track down. So be sure to lock everything with readwrite spin locks (as the nature of the activity on the data is many reads and rare writes).

As a last remark I'd like to add that none of this is really supported, as in: it's not an official api, so if you make these changes, we can't know what you changed so if you run into issues because of these changes, it's highly likely you have to fix it yourself too. But I hope with the above info it's abit more clear how things work internally. It's not rocketscience, so once you see how the various elements relate to each other it's fairly straight forward.

Frans Bouma | Lead developer LLBLGen Pro