Logical Data Source

Everyone is aware of a Data Source that is configured in the container pointing to a database that is then used within the application through a simple data source lookup. For the sake of clarity, this data source will be referred to as Container Data Source. So what is this Logical Data Source? Let us take an example.

The application is a shopping cart application that provides typical shopping cart functionality to their end customers and for internal customers, it should provide reporting capability on historic data.
 
For this application, there will typically be a database user and a Container Data Source configured against this database user for application access. But within the application, there are at the minimum two logical functionality module requiring its own set of data or query modeling – One is the actual shopping cart functionality while the other is its reporting functionality. Initially, the requirement may be to have everything together and have the complete functionality point to the single user. But over period of time and with bigger volumes, there may be a need to move historical data into a separate database and have reporting point to that database. Now the definition of having reporting point to that database effectively means that the entire data access layer logic also should be aware of and point to the database.


This effectively means that while data access layer just provides the abstraction over a data model, what is needed is a logical abstraction above the data model that splits the functionality by modules that can potentially point to different databases. This level of abstraction is what is called as the Logical Data Source.


So what constitutes a Logical Data Source? It is a combination of the following elements:

  • Target Container Data Source
  • Set of Entity / Query modeling that constitutes a logical module / layer.


The Database Access Framework works on the concept of Logical Data Source. Applications that do not see the need for this abstraction can create a single Logical Data Source pointing to their Container Data Source, thereby effectively nullifying the abstraction.


Database Access Framework focuses on separating two aspects:

  • How a developer accesses data for any operation
  • How the access is translated to any Data Access Layer that is identified for the application


Now that we have the concept of Logical data sources clear, let us look at how Database Access Framework enables the following key aspects:

  • How to execute an operation on data
  • How the execution is translated to any Data Access Layer that is identified for the application