Tuesday, August 8, 2017

Oracle Forms and Reports - Tips and Tricks

I have been developing in the Oracle Forms and Reports space for over 20 years, and consulting with many clients over the years which continues even today.

Oracle Forms and Reports development suite is still hanging in there.  Most applications are moving to a web browser front end, but there are many corporations around the world that have built custom Oracle applications against an Oracle database using Oracle Forms and Reports.  It has been more difficult to find help even from Ask TOM, so I thought I would start sharing some of my tips and tricks.

Blanking out an NBT Field in Oracle Forms that is not Mandatory
Hi everyone, here are steps required in Oracle Forms to be able to blank out an ID field linked to an NBT field that gets values from an LOV that is not mandatory.  

Add a POST-TEXT-ITEM trigger to the NBT field with the following code as an example:
IF :BLOCK_NAME.NBT_FIELD IS NULL AND :BLOCK_NAME.FIELD_ID IS NOT NULL THEN
               :BLOCK_NAME.FIELD_ID := NULL;
END IF;


This will NULL out the NBT fields corresponding ID field so that the value gets blanked out and commit/save.

Lookup the unique key value of any id field in any table based on foreign keys constraints
One of our clients has an audit table that shows the change in a value (before and after) with user and date and time along with the table name and column name.  The problem is that some of the table columns are IDs which are meaningless numbers.  This function I created will use Oracles data dictionary tables to lookup the value of the ID to display on the Audit screen by passing the originating table name, column name, and the value.  If the foreign key table has multiple unique columns, the function will concatenate all of them into one value.

Hopefully this function is useful to you, and you are welcome to tweak if needed.

FUNCTION fnGetIDValue(pIDTabName_In IN VARCHAR2, pIDColName_In IN VARCHAR2, pIDValue_In IN NUMBER) RETURN VARCHAR2 IS

CURSOR crFKTabIDCol (cpIDTabName_In IN VARCHAR2, cpIDColName_In IN VARCHAR2) IS
 SELECT c.table_name, c.column_name
  FROM user_cons_columns a
  JOIN user_constraints b ON a.owner = b.owner AND a.constraint_name = b.constraint_name
  JOIN user_cons_columns c ON b.r_constraint_name = c.constraint_name
 WHERE a.owner = 'OWNER'
   AND b.constraint_type = 'R'
   AND a.column_name = upper(cpIDColName_In)
   AND a.table_name = upper(cpIDTabName_In);
   
CURSOR crFKValCol (cpFKTabName_In IN VARCHAR2) IS   
 SELECT a.column_name
  FROM user_cons_columns a
  JOIN user_constraints b ON a.owner = b.owner AND a.constraint_name = b.constraint_name
 WHERE a.owner = 'OWNER'
   AND b.constraint_type = 'U'
   AND a.table_name = upper(cpFKTabName_In);

lvQuery        VARCHAR2(1000); 
TYPE ref_cursor IS REF CURSOR;
lvResultCursor ref_cursor;
TYPE ref_record IS RECORD ( FKNAME VARCHAR2(255) );
rcResultsRec ref_record;

lvFKTabName    VARCHAR2(50);
lvFKIDColName  VARCHAR2(50);
lvFKValColName VARCHAR2(255);
lvValue        VARCHAR2(255);
BEGIN
  lvFKTabName := NULL;
  lvFKIDColName := NULL;
  lvFKValColName := ' ';
  lvValue := NULL;
  OPEN crFKTabIDCol (cpIDTabName_In => pIDTabName_In, cpIDColName_In => pIDColName_In);
  FETCH crFKTabIDCol INTO lvFKTabName, lvFKIDColName;
  CLOSE crFKTabIDCol;

  IF lvFKTABName IS NOT NULL THEN
    FOR frFKValCol IN crFKValCol (cpFKTabName_In => lvFKTABName) LOOP
      IF lvFKValColName=  ' ' THEN
        lvFKValColName := frFKValCol.column_name;      
      ELSE
        lvFKValColName := lvFKValColName || ' || ' || '''-''' || ' || ' || frFKValCol.column_name;
      END IF;
    END LOOP;
  END IF;
  
  IF pIDValue_In IS NOT NULL THEN
    lvQuery := 'SELECT (' || lvFKValColName || ') FKName  FROM ' || lvFKTabName || ' WHERE ' || lvFKIDColName || ' = ' ||  pIDValue_In || ' ';
    debug_rec(lvQuery);
    OPEN lvResultCursor for lvQuery;
    FETCH lvResultCursor INTO rcResultsRec;
    CLOSE lvResultCursor;
  
    IF rcResultsRec.fkname IS NOT NULL THEN
      lvValue := rcResultsRec.fkname;
    END IF;
  END IF;
  
  RETURN lvValue;
END fnGetIDValue;





Tuesday, October 14, 2014

Application Prototyping and Simulation - iRise

How would you convey captured requirements to stakeholders?  Do prototyping and or simulating make sense?  And what tools would you use?  There are so many options in gathering requirements and documenting them for stakeholder review:  from static documents and spreadsheets for displaying use cases and list of requirements; diagrams and images for displaying screen mockups, wireframes, process flows; to prototyping and or simulating.  Application projects will use some or all of these options. 

Because most stakeholders don’t know what they want until they see and interact with the application; and because they often have difficulty with interpreting text specifications, use cases, diagrams, and screen shots; and depending on the project budget and the size of the application you may want to consider prototyping and or simulating your application, or even parts of your application.  This will help:
·         build what the targeted audience expects with no surprises
·         test drive functionality, concepts and complex navigations
·         reduce rework
·         get requirements right the first time
·         capture all required functionality
·         save on total project time and costs
·         get the right Look and Feel
·         envision a future state

It is always a challenge to get the right look and feel and capture all the required functionality in your application.  That is why it is important to include prototyping and or simulations as part of the analysis and requirements gathering process, where it makes sense.  Engage your stakeholders earlier in the design process having them review prototypes and or run simulations, and provide feedback. 

There are many techniques and tools that can be used to prototype and simulate your application.  From mockups and storyboards drawn up or created with graphic programs, to more sophisticated applications that create workable simulations attached to requirements with the ability to add comments for feedback.  
Below is a short list of popular options for prototyping and simulating applications:

Product
Price Range
Description
Features
Map Require-ments
Version-ing
Simul-ation
Capture
Feedback
Paper
$0
Storyboard and prototype on paper 
Poor
No
Poor
No
No
Paint Programs
$0
Edit images or create images manually
Poor
No
Poor
No
No
Snagit
$20-$40
Screen capture and editing tool
Good
No
Poor
No
No
PowerPoint
Comes with MS Office
Presentation Tool.  Storyboard shapes with Visual Studio (Requires VS)
Poor
No
Poor
Poor
Poor
Balsamiq Mockups
$80
Prototyping tool
Good
Yes
Poor
No
Yes
Azure RP
$300
Prototyping and simulation tool
Good
Yes
Good
Yes
Yes
Serena Prototype Composer
$350
Prototyping and simulation tool
Great
Yes
Good
Yes
Yes
Justinmind Prototyper
$500
Prototyping and simulation tool
Great
Yes
Good
Yes
Yes
iRise Studio MX
$0 (Limited)
Prototyping and Simulation tool for iPhone and iPads, limited to 3 active projects and 10 screens
Excellent
Yes
Good
Yes
Yes
iRise Studio
$5000+
Professional Prototyping and Simulation tool
Excellent
Yes
Good
Yes
Yes
IBM Rational DOORS
$1,000-$10,000
Professional Requirements Management tool
Excellent
Yes
Excellent
No
Yes

My personal best has been iRise for projects that make sense for prototyping and or simulating, it has a robust set of features, and very intuitive to work with.  For smaller projects or small enhancements I always use Snagit for creating screen mockups.   It took me no time at all to learn and start using the iRise software.  However, building more complex prototypes and simulations took some time to master.  The end results are simulations that can feel like a working application, depending on how much detail you put into it.

A little information on the iRise software

iRise simulations are interactive previews that “Look”, “Act”, and “Feel” like real software. 

iRise Studio (MX) software features:

  •      creating prototypes and simulations for web, desktop, and mobile applications
  •           building templates and master objects
  •            tons of downloadable widgets from iRise.com, iBlocs
  •      create reusable widgets
  •           create data tables to use in your simulation
  •          map prototypes and simulations to requirements, and quickly create a document of all screens, requirements, and comments
  •     document screen flows
  •          MX supports templates for iPad and iPhone applications
  •          secure and real-time collaboration, differentiating authors and reviewers
  •          and more…
iRise Definition Center is the hub for collaboration and allows a group of users to securely collaborate on the design and for stakeholders to review prototypes and simulations over the internet, from anywhere.

If you have any questions about iRise, please give me a shout!

An iRise Expert,
Ray