1--PL/SQL-Main Features of PL/SQL

Main Features of PL/SQL

  • Error Handling
    PL/SQL makes it easy to detect and handle errors.

When an error occurs, PL/SQL raises an exception. Normal execution stops and control transfers to the exception-handling part of the PL/SQL block. You do not have to check every operation to ensure that it succeeded, as in a C program.

  • Blocks

The basic unit of a PL/SQL source program is the block, which groups related declarations and statements.

A PL/SQL block is defined by the keywords DECLARE, BEGIN, EXCEPTION, and END. These keywords divide the block into a declarative part, an executable part, and an exception-handling part. Only the executable part is required. A block can have a label.

Declarations are local to the block and cease to exist when the block completes execution, helping to avoid cluttered namespaces for variables and subprograms.

Blocks can be nested: Because a block is an executable statement, it can appear in another block wherever an executable statement is allowed.

You can submit a block to an interactive tool (such as SQL*Plus or Enterprise Manager) or embed it in an Oracle Precompiler or OCI program. The interactive tool or program runs the block one time. The block is not stored in the database, and for that reason, it is called an anonymous block (even if it has a label).

An anonymous block is compiled each time it is loaded into memory, and its compilation has three stages:

Syntax checking: PL/SQL syntax is checked, and a parse tree is generated.

Semantic checking: Type checking and further processing on the parse tree.

Code generation

Note:An anonymous block is a SQL statement.

This example shows the basic structure of a PL/SQL block.

Copy

sql 复制代码
<< label >> (optional)
DECLARE    -- Declarative part (optional)
  -- Declarations of local types, variables, & subprograms

BEGIN      -- Executable part (required)
  -- Statements (which can use items declared in declarative part)

[EXCEPTION -- Exception-handling part (optional)
  -- Exception handlers for exceptions (errors) raised in executable part]
END;
  • Variables and Constants

L/SQL lets you declare variables and constants, and then use them wherever you can use an expression.

As the program runs, the values of variables can change, but the values of constants cannot.

  • Subprograms
    A PL/SQL subprogram is a named PL/SQL block that can be invoked repeatedly.
  • Packages
    A package is a schema object that groups logically related PL/SQL types, variables, constants, subprograms, cursors, and exceptions.

A package is compiled and stored in the database, where many applications can share its contents. You can think of a package as an application.

  • Triggers

    A trigger is a named PL/SQL unit that is stored in the database and run in response to an event that occurs in the database.

  • Input and Output

    Most PL/SQL input and output (I/O) is done with SQL statements that store data in database tables or query those tables. All other PL/SQL I/O is done with PL/SQL packages that Oracle Database supplies.

  • Data Abstraction

    Data abstraction lets you work with the essential properties of data without being too involved with details.

You can design a data structure first, and then design algorithms that manipulate it.

复制代码
- Cursors
- Composite Variables
- Using the %ROWTYPE Attribute
- Using the %TYPE Attribute
- Abstract Data Types
  • Control Statements

Control statements are the most important PL/SQL extension to SQL.

PL/SQL has three categories of control statements:

--Conditional selection statements, which let you run different statements for different data values.

--Loop statements, which let you repeat the same statements with a series of different data values.

--Sequential control statements, which allow you to go to a specified, labeled statement, or to do nothing.

  • Conditional Compilation
    Conditional compilation lets you customize the functionality in a PL/SQL application without removing source text.
  • Processing a Query Result Set One Row at a Time
    PL/SQL lets you issue a SQL query and process the rows of the result set one at a time.

You can use a basic loop, or you can control the process precisely by using individual statements to run the query, retrieve the results, and finish processing.

This example uses a basic loop.

sql 复制代码
BEGIN
  FOR someone IN (
    SELECT * FROM "RESOURCES"."EMPLOYEE"
    WHERE employeeID < 120
    ORDER BY employeeID
  )
  LOOP
    DBMS_OUTPUT.PUT_LINE('TITLE = ' || someone.TITLE ||
                         ', DATE = ' || someone.HAIRDATE);
  END LOOP;
END;
/

Result:

相关推荐
倔强的石头_11 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql