Skip to Content
Oracle PL/SQL for DBAs
book

Oracle PL/SQL for DBAs

by Arup Nanda, Steven Feuerstein
October 2005
Intermediate to advanced
454 pages
14h 44m
English
O'Reilly Media, Inc.
Content preview from Oracle PL/SQL for DBAs

Bulk Fetching the Criteria

Because my table function guarantees that records will be grouped by region, I can safely assume that any time the region ID value of a fetched record changes, I will have moved on to the next region. And the first thing I want to do for each region is load its repeat-order criteria into a PL/SQL associative array. I’ll accomplish this using a cursor as shown here.

    CURSOR curs_get_criteria ( cp_region NUMBER ) IS
      SELECT *
        FROM repeat_order_criteria
       WHERE region_id = cp_region;

Then, within the function, I implement a simple “last region id” check to see when the value changes, and, if it does, I bulk load the criteria:

    -- if it's a new region...
    IF NVL(v_last_region,0) <> v_order.region_id THEN

      -- set the local region ID and bulk load
      -- its criteria
      v_last_region := v_order.region_id;
      OPEN curs_get_criteria(v_order.region_id);
      FETCH curs_get_criteria BULK COLLECT INTO v_criteria;
      CLOSE curs_get_criteria;

    END IF;  -- new region

This exposes another benefit of table functions —the ability to implement focused data access within the function itself. This means that the database can focus on getting the orders with one query and the repeat criteria with another.

Getting back to the function, the pseudo-code looks like this now that I’ve added the query to get the criteria:

 BEGIN -- for every order... LOOP FETCH p_curs INTO v_order; EXIT WHEN p_curs%NOTFOUND; IF first record or new region THEN Load region criteria END IF; IF it's a repeat order then PIPE ROW( ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Oracle PL/SQL Best Practices

Oracle PL/SQL Best Practices

Steven Feuerstein
Resilient Oracle PL/SQL

Resilient Oracle PL/SQL

Stephen B. Morris
Expert Oracle PL/SQL

Expert Oracle PL/SQL

Ron Hardman, Michael McLaughlin

Publisher Resources

ISBN: 0596005873Errata Page