Oracle APEX Tabular Form Tutorial with Examples
1. Introduction
You are viewing guidelines for programming Oracle APEX 5.0. This is the 2nd document which next of:
Included in this document, I will continue to guide you on Oracle APEX Database Desktop Application, using Tabular Form.
2. Create a Tabular Form using Wizard
Log in to Oracle APEX with programmer's account.
data:image/s3,"s3://crabby-images/0f273/0f273f257ca6aadfba00a5105d813920c5e877cf" alt=""
Go to "Database Application".
data:image/s3,"s3://crabby-images/8d167/8d1672dbf0eec3171fc5e342d84c0c628c144bc3" alt=""
Next, going to "Hello Database Desktop Application" that you created in the previous guidance
data:image/s3,"s3://crabby-images/e3f32/e3f3208ab2a9c4e3ee7b4a0b50c3200ca3901aa4" alt=""
In this application, there are a few pages created in the previous tutorial. Click "Create Page" to create another page.
data:image/s3,"s3://crabby-images/a15a6/a15a63d9a24cd68e606302e4b4c3d9c90fd07b29" alt=""
data:image/s3,"s3://crabby-images/1910a/1910ade369246d3fbf4eae241fb65f8295dcdf32" alt=""
Create a Tabular Form:
data:image/s3,"s3://crabby-images/364c8/364c8a1e619cdbecafddd82e99c130066ee380d3" alt=""
data:image/s3,"s3://crabby-images/283de/283dee5059b73264b753a7eda78bf77dcaafdb82" alt=""
data:image/s3,"s3://crabby-images/da2c2/da2c24413ab7f2ae3bf2e5db441fd172d300ab89" alt=""
data:image/s3,"s3://crabby-images/7c7e8/7c7e804486193a51fc46d670ee34cb0c434d37e8" alt=""
data:image/s3,"s3://crabby-images/af05d/af05d3140f28b75a26185ca88e4ec79fb8030efb" alt=""
Enter:
- Page: 7
- Page Name: Emp Tabular Form (7)
data:image/s3,"s3://crabby-images/dd76c/dd76c94d4cbde7631fa0f7b086078931030d378d" alt=""
data:image/s3,"s3://crabby-images/03de3/03de3030c3ba670950179edf613cb1c510847364" alt=""
data:image/s3,"s3://crabby-images/f78dc/f78dcc3c373a2d8baed9b3eabefc915551861010" alt=""
data:image/s3,"s3://crabby-images/151e9/151e9b4f372b4584fbb44dca90083f64c8dbf85d" alt=""
Your web page has been created, click RUN to test the newly created page.
data:image/s3,"s3://crabby-images/aeb3a/aeb3a9d917e55bd68da291876f85c24e158c382f" alt=""
data:image/s3,"s3://crabby-images/ff1fb/ff1fb9059145d8051e618996f8667e62fa3a80b9" alt=""
Page 7 is running:
data:image/s3,"s3://crabby-images/ee139/ee139c2c2759e4ad0416b5672c8a823fb54e7b91" alt=""
Here, the question arises as to how to change some input fields into SELECT LIST or POPUP LOV (List of values). For example, you want to choose a Manager (MGR) through POPUP LOV, and select a Job through SELECT LIST.
data:image/s3,"s3://crabby-images/f064b/f064be3bdf600417a136b9e74cc5f152110436af" alt=""
Return to the design screen of page 7. Set the properties for the JOB column so that it displays as a SELECT LIST.
Identification:
- Type: Select List
- Type: Static Value
- Static Value:
STATIC:
CLERK;CLERK,
SALESMAN;SALESMAN,
PRESIDENT;PRESIDENT,
MANAGER;MANAGER,
ANALYST;ANALYST
The syntax used to declare the static values
STATIC:Display1;Return1,Display2;Return2
data:image/s3,"s3://crabby-images/10fa2/10fa2b7a354c706b205a18fcf37383fce7e11ff0" alt=""
Next, you need to set the properties for the MGR so that it shows up as POPUP LOV (list of values)
Identification:
- Type: Popup LOV (shows display values)
- Type: SQL Query
- SQL Query: Select emp.ename, emp.empno from Emp
data:image/s3,"s3://crabby-images/413a1/413a128a6d8f8e3e233f3635d708cf81c928272d" alt=""
Similarly set the properties for DEPTNO, so that it displays as a POPUP LOV.
Identification:
- Type: Popup LOV (shows display values)
- Type: SQL Query
- SQL Query: Select d.dname, d.deptno from Dept d
data:image/s3,"s3://crabby-images/8d38c/8d38ce55bf3812620efb94d215ee08f8dfdfc910" alt=""
Save and run the Page 7:
data:image/s3,"s3://crabby-images/d29e8/d29e86aca8ac55a29c589df7d7f113a3ccccca1b" alt=""
data:image/s3,"s3://crabby-images/1a6c6/1a6c6be9ad6a3ee5738190a8bf8eb379827d211f" alt=""
3. Create Tabular Form manually
Above, I showed you how to create a Tabular Form by using the wizard of Oracle Apex. Next we will create completely from scratch a Tabular Form, not using the wizard, which will help you understand more about Tabular Form & Oracle APEX.
data:image/s3,"s3://crabby-images/b6c72/b6c726329f228ac07e747d6d581500f569518a0a" alt=""
Enter:
- Page Number: 8
- Name: Emp Tabular Form (8)
data:image/s3,"s3://crabby-images/214c4/214c4f4c761393e9d00e111055f245fd45dbdf70" alt=""
data:image/s3,"s3://crabby-images/41408/41408a659b47e6ae03cee1cefec1937f9ea6a330" alt=""
A blank page has been created.
data:image/s3,"s3://crabby-images/f5b84/f5b84e99edba68b218587e45fd6b51c72f29d9c8" alt=""
Create a Tabular Form in the "Content Body" region:
data:image/s3,"s3://crabby-images/92cbb/92cbb239853666deea2d054ae1132cc87c06f32b" alt=""
- Title: Emp Tabular Form (8)
- Type: Tabular Form
- SQL Query:
select EMPNO,
EMPNO EMPNO_DISPLAY,
ENAME,
JOB,
MGR,
HIREDATE,
SAL,
COMM,
DEPTNO
from EMP
data:image/s3,"s3://crabby-images/6fca0/6fca0d90540508318ad160d157ed596a1a5a2e2c" alt=""
You can test page 8, result is as follows:
data:image/s3,"s3://crabby-images/d3fbc/d3fbc7c460aab975990fc9c9cda6427f70ef5148" alt=""
Add a column contains Checkbox, which used to select rows.
data:image/s3,"s3://crabby-images/c5828/c5828205487de6e92968eec8f1aa4d1ba9b496d6" alt=""
data:image/s3,"s3://crabby-images/770c2/770c22c709a7b7142ce9f66e05554d9db187ec35" alt=""
Set attributes for EMPNO, hide this column, and set the primary key attribute for it.
Identification
Primary Key Source
- Column Name: EMPNO
- Type: Hidden Column (saves state)
Primary Key Source
- Type: Existing sequence
- Name: EMP_SEQ
data:image/s3,"s3://crabby-images/fa23f/fa23fb423b24b1b152eda5e90eb3a00b9735a4ee" alt=""
Column ENAME:
Identification
- Column Name: ENAME
- Type: Text Field
data:image/s3,"s3://crabby-images/8009b/8009b7bf76837d4177837d089fae54642b59008b" alt=""
Column JOB:
Identification
List of Values
- Column Name: JOB
- Type: Select List
List of Values
- Type: Static Values
- Static Values:
STATIC:
CLERK;CLERK,
SALESMAN;SALESMAN,
PRESIDENT;PRESIDENT,
MANAGER;MANAGER,
ANALYST;ANALYST
data:image/s3,"s3://crabby-images/66a11/66a11c895467aacfdfe872f44432b1d0d46a25f8" alt=""
Column MGR:
Identification
List of Values
- Column Name: MGR
- Type: Popup LOV (shows display values)
List of Values
- Type: SQL Query
- Static Values: Select emp.ename, emp.empno from Emp
data:image/s3,"s3://crabby-images/a5257/a5257ae735828af7334d556225b3c1c618d0d2e6" alt=""
Column HIREDATE:
Identification
- Column Name: HIDEDATE
- Type: Date Picker
- Format Mask: YYYY-MM-DD
- Type: PL/SQL Expression
- PL/SQL Expression: sysdate
data:image/s3,"s3://crabby-images/41365/413658c7a2f8d40ca36632cd4bef8dda0905092e" alt=""
Column SAL:
Identification
- Column Name: SAL
- Type: Text Field
data:image/s3,"s3://crabby-images/e7dcc/e7dccca8eed3e0514d1be0556a8729fb352e38c1" alt=""
SAL (Salary) Column is a type of numeric, so you need to add validation:
data:image/s3,"s3://crabby-images/53258/532582743250ff63fa086b12eeabefb6fa4b5592" alt=""
Identification
- Name: SAL must be numeric
- Type: Column is numeric
- Column: SAL
- Error Message: #COLUMN_HEADER# must have a value.
- Display Location: Inline with Field and in Notification
Note :
- #COLUMN_HEADER# is one that acts as a Place Holder, it will be replaced by the title of the corresponding column at runtime.
data:image/s3,"s3://crabby-images/29fc7/29fc76680281c7f108a9ef49aeb10fa872ec5f50" alt=""
Column COMM:
Identification
- Column Name: COMM
- Type: Text Field
data:image/s3,"s3://crabby-images/4caf5/4caf5d542e9176cf4cf223ed85355529486f7f3f" alt=""
Create Validation for COMM, COMM must be numeric.
Identification
- Name: COMM must be numeric
- Type: Column is numeric
- Column: COMM
- Error Message: #COLUMN_HEADER# must have a value.
- Display Location: Inline with Field and in Notification
data:image/s3,"s3://crabby-images/0bdc5/0bdc5debd0bc758186fbed592da8aec452f1aef8" alt=""
Column DEPTNO:
Identification:
- Type: Popup LOV (shows display values)
- Type: SQL Query
- SQL Query: Select d.dname, d.deptno from Dept d
data:image/s3,"s3://crabby-images/23c23/23c231160a73395cfe96177e5088ceafde97247f" alt=""
4. Handling Tabular form
Next we need to add more processing includes create row, edit rows, delete rows
data:image/s3,"s3://crabby-images/8b73d/8b73d124242f541fe338d1d8ff6e8d9d4e637e3e" alt=""
data:image/s3,"s3://crabby-images/a663a/a663afd868350c9b84639885258b379f5d11ea76" alt=""
Change name of the buttons, as shown below:
data:image/s3,"s3://crabby-images/39e56/39e56b6fb18926763bc97f2fd9d24772bd411301" alt=""
For Cancel button:
When the user clicks the Cancel button, website will refresh the current page (Here is page 8).
data:image/s3,"s3://crabby-images/30604/30604e5f41c1da74a201b3bdab97d62a5c2c70cd" alt=""
data:image/s3,"s3://crabby-images/db07a/db07ac7bd33e444622d9a2081ac6e4b0b1e2ec25" alt=""
data:image/s3,"s3://crabby-images/92aae/92aae21a4a550a9c01dcf4b3731882d38e5a9a41" alt=""
Add rows
When users click on the ADD button, table on page will automatically add a new row, which allows user to enter data. You need to call javascript function to accomplish this.
Idetification
Behavior
- Button Name: ADD
- Label: Add
Behavior
- Action: Redirect to URL
- Target: javascript:apex.widget.tabular.addRow();
data:image/s3,"s3://crabby-images/deff3/deff372023317fcd7869bdb62407092efdc1b607" alt=""
Multiple row update
Idetification
Behavior
- Button Name: SAVE
- Label: Save
Behavior
- Action: Submit Page
data:image/s3,"s3://crabby-images/20dd6/20dd68e19b15b990f4bc6bb7c525fb9e35e7b4b5" alt=""
SAVE button need to save the information of several records at once, including new records, modified records. You need to declare a process to handle this. This process will be run once immediately after the page is called, it will update the records that have changes and insert new records.
data:image/s3,"s3://crabby-images/edde2/edde267e459c86201f1873f91b7a31e1b5dc2e9c" alt=""
Create Process:
data:image/s3,"s3://crabby-images/ad087/ad087556ffb2e09249c4d7e849e1ba34bc0e0993" alt=""
Idetification
Settings
Execution Options
Success Messages
Condition
- Name: ApplyMRU
- Type: Tabular Form - Multi Row Update
Settings
- Table Name: EMP
- Primary Key Column: EMPNO
Execution Options
- Tabular Form: Emp Tabular Form (8)
- Run Process: Once Per Page Visit (default)
Success Messages
- Success Message: #MRU_COUNT# row(s) updated, #MRI_COUNT# row(s) inserted.
Condition
- When Button Pressed: SAVE (Name of button)
- Execution Scope: For Created and Modified Rows
data:image/s3,"s3://crabby-images/11dc4/11dc4fc7f4e5f6a73f07cd32da7bce4b0688826a" alt=""
data:image/s3,"s3://crabby-images/c3419/c3419a58b7da5ff2e7a87bfbdf64087f165012ca" alt=""
Deleting multiple rows immediately
Handling button to immediately delete the selected records, no need to confirm:
data:image/s3,"s3://crabby-images/eabab/eabab3d2316cce5b5996f66cabd1372e585d61f8" alt=""
To delete many rows you need to create a Process to handle this. This process will be executed once as soon as the page is called.
data:image/s3,"s3://crabby-images/fe8f3/fe8f3ee64e8af9ad60758597ad62faa45b9175df" alt=""
Create Process:
data:image/s3,"s3://crabby-images/68bf3/68bf3ae3b7248f0da1cb8b1aebf0afd0cbdcf99b" alt=""
Idetification
Settings
Execution Options
Success Messages
Condition
- Name: ApplyMRD_IMMEDIATELY
- Type: Tabular Form - Multi Row Delete
Settings
- Table Name: EMP
- Primary Key Column: EMPNO
Execution Options
- Tabular Form: Emp Tabular Form (8)
- Run Process: Once Per Page Visit (default)
Success Messages
- Success Message: #MRD_COUNT# row(s) deleted.
Condition
- When Button Pressed: IMMEDIATELY_MULTY_ROW_DELETE (Name of button)
- Execution Scope: For Created and Modified Rows
data:image/s3,"s3://crabby-images/9cb0e/9cb0e89443bf28d588c751c4252ffad692b39081" alt=""
data:image/s3,"s3://crabby-images/00aea/00aead85a46ef2a11529832692492fe3711ee9bd" alt=""
Deleting multiple rows - Prompt before deleting
Before deleting records, the program asks whether the user agrees to delete or not?
Idetification
Behavior
- Button Name: MULTI_ROW_DELETE
- Label: Multi Row Delete
Behavior
- Action: Redirect URL
- Target: javascript:apex.confirm('Are you sure to delete?','MULTI_ROW_DELETE');
data:image/s3,"s3://crabby-images/f4816/f48165df697f3ae0516da24a73eb6caab71a514c" alt=""
apex.confirm (...) is a JavaScript function used to ask the user before executing the command of button.
// The function includes 2 parameters, message and Button Name.
apex.confirm('Message ...', 'Button Name');
// Example:
apex.confirm('Are you sure to delete?','MULTI_ROW_DELETE');
// Using variable.
// htmldb_delete_message is a javascript variable
// with value: 'Would you like to perform this delete action?'
// (You need to declare this variable).
apex.confirm(htmldb_delete_message,'MULTI_ROW_DELETE');
data:image/s3,"s3://crabby-images/ef710/ef71097ea110b60b27656c16efe7aa1abe32c439" alt=""
// Declare a variable named htmldb_delete_message
var htmldb_delete_message='Would you like to perform this delete action?';
// Or:
// "DELETE_CONFIRM_MSG" is a constant available in APEX.
// It has value: Would you like to delete this thực action?
var htmldb_delete_message='"DELETE_CONFIRM_MSG"';
// Then can use this variable in the whole page.
apex.confirm(htmldb_delete_message,'MULTI_ROW_DELETE');
To delete many rows you need to create a Process to handle this. This process will be executed once as soon as the page is called.
Idetification
Settings
Execution Options
Success Messages
Condition
- Name: ApplyMRD
- Type: Tabular Form - Multi Row Delete
Settings
- Table Name: EMP
- Primary Key Column: EMPNO
Execution Options
- Tabular Form: Emp Tabular Form (8)
- Run Process: Once Per Page Visit (default)
Success Messages
- Success Message: #MRD_COUNT# row(s) deleted.
Condition
- Execution Scope: For Created and Modified Rows
- Type: Request = Value
- Value: MULTI_ROW_DELETE
- Execute Condition: Once
data:image/s3,"s3://crabby-images/238b4/238b48467a9ebe9286529037f575d377734e4b28" alt=""
data:image/s3,"s3://crabby-images/8a603/8a6033859572f4668b26b09b16678631d8878b7e" alt=""
Oracle APEX Tutorials
- What is Oracle Application Express?
- Install Oracle Apex 5.0
- Install Oracle REST Data Services (ORDS) for Oracle APEX
- Oracle APEX Tutorial for Beginners (APEX 5.0)
- Oracle APEX Tabular Form Tutorial with Examples
- Oracle APEX Master Details Tutorial with Examples
- Custom Authentication in Oracle APEX
- Oracle APEX Dynamic Action Tutorial with Examples
- Create Dynamic Content Region in Oracle APEX (PL/SQL Dynamic Content)
- What is Business Intelligence?
- Install Oracle BI 11g
Show More