(Created page with "MDriven Server – the new name for BorPred – has been extended with functionality to import data from other sqlbased systems. The MDriven Server is designed for taking car...") |
No edit summary |
||
Line 3: | Line 3: | ||
The MDriven Server is designed for taking care of the repetitive common tasks that always seems to come back and haunt us system developers. MDriven Server takes a strictly model driven approach to help you with the work. | The MDriven Server is designed for taking care of the repetitive common tasks that always seems to come back and haunt us system developers. MDriven Server takes a strictly model driven approach to help you with the work. | ||
Earlier I described how to export files | Earlier I described how to export files [[Exporting files from MDriven Server|Exporting files from MDriven Server#Producing export files from MDriven Server]] | ||
and this here is a link to explain more about the concept periodic actions | and this here is a link to explain more about the concept periodic actions [[MDrivenServer periodic server-side actions]] | ||
What is new today is the ability to read from an external SQL server and import that data – strictly by using MDriven techniques and zero need for external programs. | What is new today is the ability to read from an external SQL server and import that data – strictly by using MDriven techniques and zero need for external programs. | ||
Line 16: | Line 16: | ||
So I declare a viewModel that looks like this: | So I declare a viewModel that looks like this: | ||
[[File:Import - 2.png|frameless|489x489px]] | |||
It defines 4 columns with data and 2 actions. | It defines 4 columns with data and 2 actions. | ||
Line 29: | Line 31: | ||
And the actions: | And the actions: | ||
SQLImport – using this name will trigger the import function in MDriven Server | '''SQLImport''' – using this name will trigger the import function in MDriven Server | ||
Finished – this is a generic action – that just execute the expression – in this case setting Class2.Attribute1 to ‘Done’ | Finished – this is a generic action – that just execute the expression – in this case setting Class2.Attribute1 to ‘Done’ | ||
So the SQL data returned looks like this: | So the SQL data returned looks like this: | ||
[[File:Import - 3.png|frameless]] | |||
And the ViewModel that is going to act as the import template – called “TheImporter” in the example above looks like this: | And the ViewModel that is going to act as the import template – called “TheImporter” in the example above looks like this: | ||
[[File:Import - 4.png|frameless]] | |||
I now declare the ServerSide job in MDriven server: | I now declare the ServerSide job in MDriven server: | ||
The actual import is executed by the import logic described here: | [[File:Import - 5.jpg|frameless|465x465px]] | ||
The actual import is executed by the import logic described here: [[Import Data]] | |||
Now the MDriven Server will check every 20:seconds if the expression Class2.allinstances->select(attribute1=’todo’) returns any rows. If it does - it fetches at most 2 of these and executes all the actions found in TheServerSideJob. | Now the MDriven Server will check every 20:seconds if the expression Class2.allinstances->select(attribute1=’todo’) returns any rows. If it does - it fetches at most 2 of these and executes all the actions found in TheServerSideJob. | ||
In MDriven Designer (formerly AppComplete) I can create a Class2 with the debugger and save it: | In MDriven Designer (formerly AppComplete) I can create a Class2 with the debugger and save it: | ||
[[File:Import - 7.png|frameless]] | |||
And then I check the MDriven Server log: | And then I check the MDriven Server log: | ||
[[File:Import - 8.png|frameless|453x453px]] | |||
I then check my Class2: | I then check my Class2: | ||
[[File:Import - 9.png|frameless]] | |||
Attribute1 is now ‘Done’ – so the serverside job relaxes and will not find anything more to do just now… | Attribute1 is now ‘Done’ – so the serverside job relaxes and will not find anything more to do just now… |
Revision as of 14:42, 21 October 2018
MDriven Server – the new name for BorPred – has been extended with functionality to import data from other sqlbased systems.
The MDriven Server is designed for taking care of the repetitive common tasks that always seems to come back and haunt us system developers. MDriven Server takes a strictly model driven approach to help you with the work.
Earlier I described how to export files Exporting files from MDriven Server#Producing export files from MDriven Server
and this here is a link to explain more about the concept periodic actions MDrivenServer periodic server-side actions
What is new today is the ability to read from an external SQL server and import that data – strictly by using MDriven techniques and zero need for external programs.
Let me show you.
I have this model and I really want class1 to be reference data from an external database:
So I declare a viewModel that looks like this:
It defines 4 columns with data and 2 actions.
1=ViewModel - the name of yet another viewmodel that will act as a importer of the sql result set
2=Connectionstring- the external database
3=Query – the sql query – remember that you can build it with data from the rest of your model
4=Key – if we want the import to be able to update Class1 we need to explain what the key is in the class
And the actions:
SQLImport – using this name will trigger the import function in MDriven Server
Finished – this is a generic action – that just execute the expression – in this case setting Class2.Attribute1 to ‘Done’
So the SQL data returned looks like this:
And the ViewModel that is going to act as the import template – called “TheImporter” in the example above looks like this:
I now declare the ServerSide job in MDriven server:
The actual import is executed by the import logic described here: Import Data
Now the MDriven Server will check every 20:seconds if the expression Class2.allinstances->select(attribute1=’todo’) returns any rows. If it does - it fetches at most 2 of these and executes all the actions found in TheServerSideJob.
In MDriven Designer (formerly AppComplete) I can create a Class2 with the debugger and save it:
And then I check the MDriven Server log:
I then check my Class2:
Attribute1 is now ‘Done’ – so the serverside job relaxes and will not find anything more to do just now…