| File | Date | Author | Commit | 
|---|---|---|---|
| dist | 2017-07-18 |  Yogesh | [bb2cfc] Adding dist | 
| src | 2017-07-18 |  Yogesh | [2f40ba] Latest Changes | 
| .classpath | 2017-07-18 |  Yogesh | [2f40ba] Latest Changes | 
| README.md | 2017-07-13 |  yogeshsd | [894624] Update README.md | 
| pom.xml | 2017-07-13 |  Yogesh Deshpande | [32c5a3] Cleanup | 
How many times have we run SQL queries on RDBS using rich SQL editors to extract data, copy it to excel sheet to plot simple trend charts? Why do we not use any of the existing BI or reporting tools?
The overhead of using heavy weight BI tools is little too much for a simple report/charting requirement. Firstly, you need to have a licensed version, trial versions are good but they don’t offer continuity. Secondly, there is a learning curve associated in building reports no one lets you transform just the SQL queries to chart directly, you need to know the product in building even a simple report.
Query2Report addresses both these limitations. It’s an open source, web based reporting solution that lets you map SQL queries to beautiful reports using google charts. Q2R transforms bunch SQL queries to charts and displays in a report. Each report has one or more elements arranged in rows and columns. Each element has title, SQL Query, database connection pointing to database from where data is retrieved and type of graph/table renderer.
The application uses google charts. The chart element supported by LWR are
    1.  Bar Chart
    2.  Bar Stack Chart
    3.  Column Chart
    4.  Column Stack Chart
    5.  Line Chart
    6.  Pie Chart
    7.  Tabular Chart
User has to define database connection by providing the username, password, driver and connection URL. This connection is later used to create report element. We can define multiple database connection pointing to different databases and use them in different elements of a report thus retrieving data from different databases.
Each user has an option of making one of the connection as default so that same report can retrieve data from different database based on user's default database. For example production users for whom the default database is marked as the production database can see data coming from production database while the non-production users see the same report but data coming from non-production database.
When the report is rendered in browser, each element makes an Ajax call to retrieving data from database and rendering them into a chart. What gets loaded when user clicks on a report is the report template while the actual elements are rendered in parallel hence user doesn’t have to wait un till the entire report is rendered.
The application is built using HTML5 and bootstrap CSS for enhanced user experience.
The application is based on AjgularJS framework making it easy to extend and faster performance. 
The application is based on responsive web design which makes the user interface compatitable with any device like laptops, tablets and mobile phones.
Report building is web based, hence doesn’t require any rich java client to be installed on the laptop/desktop.
Report elements are loaded in parallel using AJAX and hence user need not wait for entire report to be rendered before see data/charts for simpler and smaller reporting elements. 
Report elements have autorefresh property which when enabled will refresh the report element automatically every configured refresh interval seconds. The idea behind providing the refresh at element level and also on demand is to prevent resource over utilization. User might want to see only one component’s/element’s data in real time and in such cases refresh entire report can be an over kill.
The application backend logic is implemented using RESTful web service which can be hosted on different server independently.
The application uses connection pool hence administrator can restrict the number of connections that the application can make to database. If the database connections are exhausted, the corresponding report query is queued. The connection pool is maintained per database connection defined.
•   Tomcat Application Server v8.0 and above
•   Required JDBC Driver(s) to connect to database(s)
Copy the q2r.war file downloaded from sourceforge.net and place it under CATALINA_HOME/webapps/ directory. Query2Reporter uses JDBC to connect to database(s). The JDBC drivers for Postgres and MySQL are already bundled into the war file. To connect to any other database vendor, copy the required vendor specific JDBC jar file to CATALINA_HOME/webapps/lwr/WEB-INF/lib folder and restart the tomcat server
Access the application using below URL, 
        http://<hostname>:<port>/q2r 
    Where port -> port on which tomcat is listening</port></hostname>
Once you open this URL in your browsers you would be redirected to login page that asks you for username and password. The default username is "admin" and default password is "admin". It is highly recommended to change the password for "admin" user by navigating to Administration->User Management page. You can create more users.
Create a database connection by going to Administrator -> Connection Management. Connection is created by providing
    •   Username
    •   Password
    •   JDBC Driver Class
    •   JDBC Driver URL
Once these properties are keyed in, performn test connection to check if the connectivity is established using above mentioned properties. If test connection is successful, save the connection details.
The application lets you define one or more such connections pointing to different databases and within a report we can pick data from different connections.
A single report having multiple elements can retrive data from one or more databases. Support Chart Types are
    •   Pie Chart
    •   Line Chart
    •   Bar Chart
    •   Bar Chart Stacked
    •   Column Chart
    •   Column Chart Stacked
    •   Table Chart