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/15dbc/15dbc5b0cea198cc51f535bf2ba4ebd48b22a764" alt=""
Create the ADF App
1. Create an ADF app of type – Fusion Web Application (ADF)
data:image/s3,"s3://crabby-images/0b254/0b254453146e113379850318f60e10462eae31b8" 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/0325c/0325caf69230ba3b7bcfb15ee44eabc015d800cc" alt=""
2.1.1. Create a new DB connection for scott
data:image/s3,"s3://crabby-images/cb580/cb58027c4ff4021db1204482211a90ab6daee41e" alt=""
2.1.2. Select Entity Objects
data:image/s3,"s3://crabby-images/e9b24/e9b24207b7d5029245b97f37b3711328d8de0348" alt=""
data:image/s3,"s3://crabby-images/f6851/f685122fd738f03fecc13ee223efe183dbff502a" 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/ec54d/ec54dfa436f92a76b97c5aff2ab43fdfae143dfa" alt=""
data:image/s3,"s3://crabby-images/c91c9/c91c9efa4cd5cb7059476dd0263adba99e7e4663" 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/f65f1/f65f1cd1c9f9b0aacc4b8a98b790c0bc210cee1a" alt=""
4.3 Double click on hierarchy.jspx to create the page
4.4. Open the Data Controls
data:image/s3,"s3://crabby-images/c55e9/c55e9693f3d6dca2b9bd7380d8584f8fc88095ee" alt=""
4.5 Drop CountryView1 as Hierarchy Viewer...
Radialdata:image/s3,"s3://crabby-images/6e006/6e0069992db6852cedbf254f98b27819d651d8a8" alt=""
data:image/s3,"s3://crabby-images/8a1db/8a1db61dda20956c413199495ffb488435f89438" alt=""
data:image/s3,"s3://crabby-images/e2b03/e2b037cb7cc37a5f49f89c57704ee396397bca4f" alt=""
data:image/s3,"s3://crabby-images/51ac8/51ac8e8615a577140bd1f4e4e1023961e5cc3b39" alt=""
No comments:
Post a Comment