What is PL/SQL?
Oracle PL/SQL is an extension of SQL language that combines the data manipulation power of SQL with the processing power of procedural language to create super powerful SQL queries. PL/SQL ensures seamless processing of SQL statements by enhancing the security, portability, and robustness of the Database.
PL/SQL means instructing the compiler ‘what to do’ through SQL and ‘how to do’ through its procedural way. Similar to other database languages, it gives more control to the programmers by the use of loops, conditions and object-oriented concepts. The PL/SQL Full form is “Procedural Language extensions to SQL”.
In this PL/SQL Tutorial, you will learn PL/SQL basics-
- What is PL/SQL Developer?
- Architecture of PL/SQL
- Features & Advantages of PL/SQL
- Disadvantages of PL/SQL
- Difference between SQL and PL/SQL
PL/SQL Developer is a free Integrated Development Environment provided by Oracle to develop Software in Oracle Database environment and perform various Database tasks with ease. The PL/SQL Developer IDE provides with GUI and Plugins to use in order to help the end users save the time on their Database tasks.
The Below PL/SQL Example is a pictorial representation of PL/SQL Architecture.
The PL/SQL architecture mainly consists of following three components:
- PL/SQL Block
- PL/SQL Engine
- Database Server
- This is the component which has the actual PL/SQL code.
- This consists of different sections to divide the code logically (declarative section for declaring purpose, execution section for processing statements, exception handling section for handling errors)
- It also contains the SQL instruction that used to interact with the database server.
- All the PL/SQL units are treated as PL/SQL blocks, and this is the starting stage of the architecture which serves as the primary input.
Following are the different type of PL/SQL units.
- Anonymous Block
- Package Body
- Package Specification
- Type Body
- PL/SQL engine is the component where the actual processing of the codes takes place.
- PL/SQL engine separates PL/SQL units and SQL part in the input (as shown in the image below).
- The separated PL/SQL units will be handled by the PL/SQL engine itself.
- The SQL part will be sent to database server where the actual interaction with database takes place.
- It can be installed in both database server and in the application server.
- This is the most important component of Pl/SQL unit which stores the data.
- The PL/SQL engine uses the SQL from PL/SQL units to interact with the database server.
- It consists of SQL executor which parses the input SQL statements and execute the same.
- Better performance, as SQL is executed in bulk rather than a single statement
- High Productivity
- Tight integration with SQL
- Full Portability
- Tight Security
- Supports Object Oriented Programming concepts.
- Scalability and Manageability
- Supports Web Application Development
- Supports Server Page Development
- Stored Procedures in PL/SQL uses high memory
- Lacks functionality debugging in stored procedures
- Any change in underlying database requires change in the presentation layer also
- Does not completely separate roles of back-end developer and fron-end developer
- Difficult to separate HTML development with PL/SQL development