PL/SQL Fundamentals Exercises: PL/SQL Variable Declarations
PL/SQL Fundamentals: Exercise-7 with Solution
Write PL/SQL blocks to show the declaration of variables.
The following PL/SQL block shows how to declare variables with scalar data type.
PL/SQL Code:
DECLARE
item_number NUMBER(5); -- SQL data type
item_name VARCHAR2(20); -- SQL data type
stock_yn BOOLEAN; -- PL/SQL-only data type
item_rate NUMBER(8,2); -- SQL data type
item_description VARCHAR2(40); -- SQL data type
BEGIN
NULL;
END;
/
Declaration of constant with scalar data type.
PL/SQL Code:
DECLARE
maximum_deposit CONSTANT REAL := 25000.00; -- SQL data type
min_no_of_days CONSTANT INTEGER := 75; -- SQL data type
nominee_yn CONSTANT BOOLEAN := FALSE; -- PL/SQL-only data type
BEGIN
NULL;
END;
/
Declaration of variable with initial value
PL/SQL Code:
DECLARE
worked_no_of_days INTEGER := 15;
employee_no INTEGER := 0;
pi CONSTANT REAL := 3.14159;
radius REAL := 10;
area REAL := (pi * radius**2);
BEGIN
NULL;
END;
/
Initialize NULL by default to variable.
PL/SQL Code:
DECLARE
ctr INTEGER; -- initial value is NULL by default
BEGIN
ctr := ctr + 1; -- NULL + 1 is still NULL
IF ctr IS NULL THEN
DBMS_OUTPUT.PUT_LINE('The counter ctr is NULL.');
END IF;
END;
/
Declaration of variable with NOT NULL Constraint
PL/SQL Code:
DECLARE
acc_no INTEGER(5) NOT NULL := 9999;
x NATURALN := 9999;
y POSITIVEN := 9999;
z SIMPLE_INTEGER := 9999;
BEGIN
NULL;
END;
/
Declaration of variable as same column type
In the following example the variable first_name inherits the data type and size of the column employees.first_name, which has a NOT NULL constraint and this declaration does not need an initial value.
PL/SQL Code:
DECLARE
first_name employees.first_name%TYPE;
BEGIN
DBMS_OUTPUT.PUT_LINE('First Name = ' || first_name);
END;
/
Sample Output:
First Name = Statement processed. 0.07 seconds
Flowchart:
Declaration of variables with scalar data type
data:image/s3,"s3://crabby-images/8b8f9/8b8f900da740bfa0ce9dbf2219d94b5cfe475f36" alt="Flowchart: PL/SQL Fundamentals Exercise - PL/SQL Variable Declarations"
Declaration of constant with scalar data type
data:image/s3,"s3://crabby-images/7e37a/7e37a92b8c3ca7dce2f3b32e8202a541cb0f55bf" alt="Flowchart: PL/SQL Fundamentals Exercise - PL/SQL Variable Declarations"
Declaration of variable with initial value
data:image/s3,"s3://crabby-images/a8e62/a8e621d2d8f9a21e3cdfc08fde9cf189ec8b2b7f" alt="Flowchart: PL/SQL Fundamentals Exercise - PL/SQL Variable Declarations"
Initialize NULL by default to variable.
data:image/s3,"s3://crabby-images/c2859/c2859fb014724cad5c8dbeed764dd2bb57b3fca2" alt="Flowchart: PL/SQL Fundamentals Exercise - PL/SQL Variable Declarations"
Declaration of variable with NOT NULL Constraint
data:image/s3,"s3://crabby-images/3010a/3010a9aa96e1c4e4fa0629f2b17cbafa896ac891" alt="Flowchart: PL/SQL Fundamentals Exercise - PL/SQL Variable Declarations"
Declaration of variable as same column type
data:image/s3,"s3://crabby-images/d16f7/d16f7f7874c05d4c61fd5f5057f4da5336cf7f51" alt="Flowchart: PL/SQL Fundamentals Exercise - PL/SQL Variable Declarations"
Declaration of variable as same type of another variable
In the following example the variable last_name inherits the data type, size, and NOT NULL constraint of the variable first_name. Because last_name does not inherit the initial value of first_name and its declaration needs an initial value (which cannot exceed 25 characters).
PL/SQL Code:
DECLARE
first_name VARCHAR(25) NOT NULL := 'Harold';
last_name first_name%TYPE := 'Jordon';
BEGIN
DBMS_OUTPUT.PUT_LINE('First Name = ' || first_name);
DBMS_OUTPUT.PUT_LINE('Last Name = ' || last_name);
END;
/
Sample Output:
First Name = Harold Last Name = Jordon Statement processed. 0.00 seconds
Flowchart:
Declaration of variable as same type of another variable
data:image/s3,"s3://crabby-images/fa587/fa58724dbd9258219632e269c6269d4a9485025e" alt="Flowchart: PL/SQL Fundamentals Exercise - PL/SQL Variable Declarations"
Improve this sample solution and post your code through Disqus
Previous: Write a PL/SQL block to show single and multiline comments.
Next: Write PL/SQL blocks to show the scope and visibility of local and global identifiers.
What is the difficulty level of this exercise?
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics