Actuate Information Objects act as a perfect bridge between the data layer and the presentation layer. They map the physical database fields to the logical fields of the generic schema described in Step 1. This is a very good alternative to the use of an alias in the SQL statement described in Step 1. Information Objects act as a separator between the data layer and presentation layer. When something changes in the data layer, only the Information Object needs to be modified, not all the report designs that use it as a data source. The following is an example Information Object that maps the physical database fields to our generic schema:
Information Objects that use the generic schema can be swapped into report designs for reuse of the presentation layer.
Tuesday, August 28, 2007
Monday, August 27, 2007
Step 2: The Presentation Layer
The second step in using the Framework of Reusable Components is to create charts, spreadsheets and report designs based on the field naming convention of the generic schema introduced in Step 1. The following is an example BIRT chart containing references to our generic schema database field names of Cat1, Date1 and Val1:
Once your report designs contain generic schema database field names, any data source created in Step 1 can be swapped into the report design. The presentation layer is now reused without having to make any modifications.
Once your report designs contain generic schema database field names, any data source created in Step 1 can be swapped into the report design. The presentation layer is now reused without having to make any modifications.
Wednesday, August 22, 2007
Step 1: The Data Layer
The first step in using the Framework of Reusable Components is to get control of the data layer. All data presented to the report designs and reusable components of the Framework need to be in the form of a generic schema. The generic schema is a set of arbitrary names for different types of data. Here is the generic schema used by the Framework:
Text fields: Cat1, Cat2, Cat3,...
Date fields: Date1, Date2, Date3,...
Number fields: Val1, Val2, Val3,...
The data source used to collect the data will return it in terms of the generic schema, namely Cat1, Date1, Val1. Here is an example SQL statement that aliases the database field names in terms of the generic schema:
select CUSTOMERS.COUNTRY as "Cat1", CUSTOMERS.CITY as "Cat2", ORDERS.ORDERDATE as "Date1", ORDERDETAILS.QUANTITYORDERED as "Val1", ORDERDETAILS.PRICE as "Val2"
from
CUSTOMERS, ORDERS, ORDERDETAILS
where
CUSTOMERS.CUSTOMERNUMBER = ORDERS.CUSTOMERNUMBER
and
ORDERS.ORDERNUMBER = ORDERDETAILS.ORDERNUMBER
Since all the reusable components in the Framework are built off this generic schema, any data source that conforms to this generic schema can be used. This means our presentation layer will be able to be reused many times over by swapping in any data source that conforms to this generic schema.
Text fields: Cat1, Cat2, Cat3,...
Date fields: Date1, Date2, Date3,...
Number fields: Val1, Val2, Val3,...
The data source used to collect the data will return it in terms of the generic schema, namely Cat1, Date1, Val1. Here is an example SQL statement that aliases the database field names in terms of the generic schema:
select CUSTOMERS.COUNTRY as "Cat1", CUSTOMERS.CITY as "Cat2", ORDERS.ORDERDATE as "Date1", ORDERDETAILS.QUANTITYORDERED as "Val1", ORDERDETAILS.PRICE as "Val2"
from
CUSTOMERS, ORDERS, ORDERDETAILS
where
CUSTOMERS.CUSTOMERNUMBER = ORDERS.CUSTOMERNUMBER
and
ORDERS.ORDERNUMBER = ORDERDETAILS.ORDERNUMBER
Since all the reusable components in the Framework are built off this generic schema, any data source that conforms to this generic schema can be used. This means our presentation layer will be able to be reused many times over by swapping in any data source that conforms to this generic schema.
Monday, August 20, 2007
Best Idea Contest (Win Prizes)
We are pleased to announce the first in a series of contests we will be running on this blog. We would like you to submit your ideas for what would be the best reusable component for your organization. The winner(s) will receive a copy of the latest version of BIRT: A Field Guide to Reporting by Diana Peh, Alethea Hannemann and Nola Hague. This is an excellent guide for learning and developing useful reports in BIRT.
Please submit your ideas in the comments of this post. And don’t be surprised if we develop a few of these ideas to show you how easy it is.
Please submit your ideas in the comments of this post. And don’t be surprised if we develop a few of these ideas to show you how easy it is.
Thursday, August 16, 2007
Introduction
A Framework of Reusable Components can mean a lot of things to a lot of different people. In Dan O'Connell's and my minds, reusable components need to built so generically that anyone will be able to use them without modification. I admit, that's a lofty goal, but even having something to start out with where a few tweaks here and there get you exactly what you need, will greatly improve productivity.
The idea of reusing the whole presentation layer, not just a component from a library at design time, is an idea DanO and I have been noodling on for a while. How cool would it be to have complete report designs, spreadsheets and dashboard controls be reused without modification, just by swapping out the underlying data source? What if there was a repository of presentation assets that was built on this concept and made available for anyone to download and use? Would you use it to swap your data into the visualizations, without modifying the presentation layer, to accelerate the building of your reporting application? I know I would in a heartbeat. This is why DanO and I are taking this idea out of concept stage and building this Framework of Reusable Components into a repository that can be used by all. As you learn this concept and start using this Framework in your own reporting applications, we're hoping you will create your own cool components and submit them back to us for inclusion into the repository so everyone can benefit from them. We would love to have this be a collaborative effort.
In upcoming blog entries, we will describe this concept in more depth, how to access the Framework of Reusable Components repository, how to make it part of your reporting application, how to create your own components, and how to submit them for inclusion into the repository.
I predict this will be a fun project to be involved in and that a lot of people will get a lot of value from it. As an engineer, I'm excited to develop some presentation assets, share them with others, and realize the potential of how this Framework can save tons of report development time.
The idea of reusing the whole presentation layer, not just a component from a library at design time, is an idea DanO and I have been noodling on for a while. How cool would it be to have complete report designs, spreadsheets and dashboard controls be reused without modification, just by swapping out the underlying data source? What if there was a repository of presentation assets that was built on this concept and made available for anyone to download and use? Would you use it to swap your data into the visualizations, without modifying the presentation layer, to accelerate the building of your reporting application? I know I would in a heartbeat. This is why DanO and I are taking this idea out of concept stage and building this Framework of Reusable Components into a repository that can be used by all. As you learn this concept and start using this Framework in your own reporting applications, we're hoping you will create your own cool components and submit them back to us for inclusion into the repository so everyone can benefit from them. We would love to have this be a collaborative effort.
In upcoming blog entries, we will describe this concept in more depth, how to access the Framework of Reusable Components repository, how to make it part of your reporting application, how to create your own components, and how to submit them for inclusion into the repository.
I predict this will be a fun project to be involved in and that a lot of people will get a lot of value from it. As an engineer, I'm excited to develop some presentation assets, share them with others, and realize the potential of how this Framework can save tons of report development time.
Subscribe to:
Posts (Atom)