In this lab I will leverage the ADF Hierarchy Viewer to display data on Countries and Regions in an innovative way.
Pre-Requisites
- 2 DB Tables --> Country, Region
CREATE TABLE COUNTRY
(
COUNTRY VARCHAR2(20 BYTE) NOT NULL,
POPULATION NUMBER(10, 0) NOT NULL,
CAPITAL VARCHAR2(100 BYTE) NOT NULL,
GNP VARCHAR2(20 BYTE) NOT NULL,
BURGER_INDEX NUMBER(3, 2) NOT NULL,
IMAGE BFILE,
COMMENTS VARCHAR2(100 BYTE)
, CONSTRAINT COUNTRY_PK PRIMARY KEY
(
COUNTRY
)
ENABLE
)
TABLESPACE "USERS"
LOGGING
PCTFREE 10
INITRANS 1
MAXTRANS 255
STORAGE
(
INITIAL 64K
MINEXTENTS 1
MAXEXTENTS 2147483645
BUFFER_POOL DEFAULT
)
;
CREATE TABLE REGION
(
REGION VARCHAR2(100 BYTE) NOT NULL,
COUNTRY VARCHAR2(20 BYTE) NOT NULL,
CAPITAL VARCHAR2(100 BYTE) NOT NULL,
IMAGE BFILE,
MOST_SCENIC_SITE VARCHAR2(100 BYTE),
COMMENTS VARCHAR2(255 BYTE)
, CONSTRAINT REGION_PK PRIMARY KEY
(
REGION
)
ENABLE
)
TABLESPACE "USERS"
LOGGING
PCTFREE 10
INITRANS 1
MAXTRANS 255
STORAGE
(
INITIAL 64K
MINEXTENTS 1
MAXEXTENTS 2147483645
BUFFER_POOL DEFAULT
)
;
ALTER TABLE REGION
ADD CONSTRAINT REGION_COUNTRY_FK FOREIGN KEY
(
COUNTRY
)
REFERENCES COUNTRY
(
COUNTRY
)
ON DELETE CASCADE ENABLE
;
Add Some Test Data, I'm using jpgs for Ireland and its 4 regions
– In SQLPLUS -->
Create or replace directory imagedir
AS 'D:\fmw11g\demos\ADF-General\images';
insert into country values (’Ireland’, 4000000, ’Dublin’, 200, 4.5,
bfilename ('IMAGEDIR', 'Ireland.JPG'), ’ Great Place to Live! ’);
insert into region values (’Leinster’, ’Ireland’, ’Dublin’,
bfilename ('IMAGEDIR', 'Leinster.JPG'), ’ Hill of Howth ’,
’ Well worth a visit! ’);
insert into region values (’Ulster’, ’Ireland’, ’Belfast’,
bfilename ('IMAGEDIR', 'Ulster.JPG'), ’ Giants Causeway’,
’ Well worth a visit! ’);
insert into region values (’Munster’, ’Ireland’, ’Cork’,
bfilename ('IMAGEDIR', 'Munster.JPG'), ’ Ring of Kerry ’,
’ Well worth a visit! ’);
insert into region values (’Connaught’, ’Ireland’, ’Galway’,
bfilename ('IMAGEDIR', 'Connaught.JPG'), ’ Connemara’,
’ Well worth a visit! ’);
Check in JDev DB Browser
data:image/s3,"s3://crabby-images/3f943/3f943c9df3f387876e6a740df3c925e83b0fc670" alt=""
Create the ADF App
1. Create an ADF app of type – Fusion Web Application (ADF)
data:image/s3,"s3://crabby-images/4fd40/4fd404adc530e3e2f5f1ca0238714f7381df772c" alt=""
1.1. Accept defaults on the next screens.
2. Right-mouse click on the Model project
2.1. New...
data:image/s3,"s3://crabby-images/27ccf/27ccf965ed847905fb3cb7d6325f8b26ee845105" alt=""
2.1.1. Create a new DB connection for scott
data:image/s3,"s3://crabby-images/7e09d/7e09d8decf316a76db2916902668b9d00076950a" alt=""
2.1.2. Select Entity Objects
data:image/s3,"s3://crabby-images/4e14b/4e14bcdf42ce326ec08ddf754d28b6f7b8f04eff" alt=""
data:image/s3,"s3://crabby-images/b627e/b627e87aacace2c8638b265d0db354542375100e" alt=""
data:image/s3,"s3://crabby-images/62a2a/62a2a12b90870ef2f5904d4ae2fbb770fe1cf0aa" alt=""
3 Add a Servlet to retrieve the BFile Images
3.1. Right-mouse click on the ViewController project and select New...
data:image/s3,"s3://crabby-images/53197/5319730b4fd0dca679a2a5f17bdd5a5c787bec98" alt=""
data:image/s3,"s3://crabby-images/a7d5d/a7d5d531ef97461e90c7505234183f0ee2c69dfc" alt=""
package view.servlet;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import javax.servlet.*;
import javax.servlet.http.*;
import oracle.jbo.ApplicationModule;
import oracle.jbo.Row;
import oracle.jbo.ViewObject;
import oracle.jbo.client.Configuration;
import oracle.jbo.domain.BFileDomain;
import oracle.jbo.domain.BlobDomain;
public class GetImagesServlet extends HttpServlet { private static final String CONTENT_TYPE = "image/jpeg; charset=windows-1252";
public void init(ServletConfig config) throws ServletException {
super.init(config);
}
public void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
response.setContentType(CONTENT_TYPE);
/* here we will pass in the country / region as key for image retrieval */
String country = request.getParameter("Country");
String region = request.getParameter("Region");
String where = "";
OutputStream os = response.getOutputStream();
// get a handle to the Application Module
String amDef = "am.AppModule";
String config = "AppModuleLocal";
ApplicationModule am = Configuration.createRootApplicationModule(amDef, config);
ViewObject vo = am.findViewObject("CountryView1");
BFileDomain image = new BFileDomain();
// set where clause for country or region and get approp. View
if (country != null){
where = "country = " + "'"+ country +"'";
vo.setWhereClause(where);
vo.executeQuery();
}
if (region != null){
where = "region = " + "'"+ region +"'";
vo = am.findViewObject("RegionView1");
vo.setWhereClause(where);
vo.executeQuery();
}
if(vo.getEstimatedRowCount() != 0){
Row row = vo.first();
image = (BFileDomain)row.getAttribute("Image");
image.openFile();
InputStream is = image.getInputStream();
// copy bfile to output
byte[] buffer = new byte[10 * 1024];
int nread;
while ((nread = is.read(buffer)) != -1)
os.write(buffer, 0, nread);
os.close();
}
vo.setWhereClause(null);
Configuration.releaseRootApplicationModule(am, false);
}
}
4. Create a jsp to display the Country hierarchy
4.1 Double click on faces-config.xml
4.2 Drop a JSF page icon onto the designer --> Rename to hierarchy.jspx
data:image/s3,"s3://crabby-images/92a93/92a930ebd83974fd5c2f0698535af112fcd6a61a" alt=""
4.3 Double click on hierarchy.jspx to create the page
4.4. Open the Data Controls
data:image/s3,"s3://crabby-images/d17ba/d17ba81e66565ecd00ec43161bf32d62e1f156e8" alt=""
4.5 Drop CountryView1 as Hierarchy Viewer...
Radialdata:image/s3,"s3://crabby-images/2b37f/2b37fd7cd5ded6d6d41fad42cbf0dba6613af05f" alt=""
data:image/s3,"s3://crabby-images/85ec4/85ec476ce91e3cc0985d9d202e98803f6be84337" alt=""
data:image/s3,"s3://crabby-images/41362/4136291befde5f40e49d43141ac1f25a2abcdc44" alt=""
data:image/s3,"s3://crabby-images/078b3/078b34e4137067f54c80a642be7094cba1e7bd11" alt=""
No comments:
Post a Comment