Showing posts with label jbo.SQLBuilderClass. Show all posts
Showing posts with label jbo.SQLBuilderClass. Show all posts
Wednesday, October 3, 2012
ADF Custom SQL Builders
ADF allows us to create and configure custom SQL builders. Since ADF’s SQL builders don’t support all the SQL Flavors, there might be a need to create your own SQL Builder and configure it.
1. Create a SQL Builder Class.
You can create a custom builder class by extending one of the following classes
oracle.jbo.server.SQL92SQLBuilderImpl
oracle.jbo.server.BaseSQLBuilderImpl
or to extend current functionality of existing builders you can also extend
oracle.jbo.server.SQLServerSQLBuilderImpl
oracle.jbo.server.DB2SQLBuilderImpl
oracle.jbo.server.OracleSQLBuilderImpl
Below is a simple example to override query to get time from the database
package a.b.c.extn;
import oracle.jbo.server.SQLBuilder;
import oracle.jbo.server.SQL92SQLBuilderImpl;
public class MySQLBuilder extends SQL92SQLBuilderImpl
{
public MySQLBuilder () {
super();
}
public static SQLBuilder getInterface()
{
return new MySQLBuilder ();
}
/* (non-Javadoc)
* @see oracle.jbo.server.BaseSQLBuilderImpl#getDbTimeQuery()
*/
public String getDbTimeQuery()
{
return "select getdate()";
}
}
2. Configuring the Custom SQL builder in the application
In the adf-config.xml, go to Business Components Tab.
Change the SQL Flavor to Custom and in the SQL Builder Class, give the class name as shown below
<adf-adfm-config xmlns="http://xmlns.oracle.com/adfm/config">
<defaults/>
<startup>
<amconfig-overrides>
<config:Database jbo.SQLBuilder="Custom"
jbo.SQLBuilderClass="a.b.c.extn.MySQLBuilder" jbo.locking.mode="optimistic"/>
</amconfig-overrides>
</startup>
Subscribe to:
Posts (Atom)