Maison  >  Article  >  base de données  >  La procédure stockée Oracle renvoie un jeu de résultats

La procédure stockée Oracle renvoie un jeu de résultats

WBOY
WBOYoriginal
2023-05-11 09:43:362150parcourir

Oracle est l'un des systèmes de gestion de bases de données relationnelles les plus connus au monde. Les procédures stockées sont l'une des fonctionnalités importantes qui nous permettent d'encapsuler un ensemble d'instructions SQL dans un bloc de code et de renvoyer un ou plusieurs ensembles de résultats. Cependant, renvoyer un jeu de résultats à partir d’une procédure stockée dans Oracle n’est pas une tâche facile. Dans cet article, nous expliquerons comment écrire une procédure stockée et renvoyer un jeu de résultats.

1. Introduction de base aux procédures stockées

Une procédure stockée est un objet de base de données similaire à une fonction. Il est écrit par un ensemble d'instructions SQL, comprenant le traitement d'un ou plusieurs paramètres d'entrée et le traitement des résultats renvoyés. Les procédures stockées peuvent recevoir des paramètres d'entrée, effectuer des calculs, des requêtes ou des opérations spécifiques et renvoyer des paramètres de sortie ou un jeu de résultats. Les procédures stockées peuvent être utilisées pour effectuer des opérations de base de données telles que la requête, la mise à jour, la suppression, l'insertion, etc.

L'avantage des procédures stockées est leur flexibilité et leur réutilisabilité. Les procédures stockées peuvent prendre en charge les entrées paramétrées et des instructions SQL complexes peuvent être écrites à l'aide de structures de contrôle logiques. Il peut également être appelé plusieurs fois par plusieurs applications clientes et peut être consulté et exécuté par différents utilisateurs et rôles.

2. Comment la procédure stockée renvoie un ensemble de résultats

Une procédure stockée peut renvoyer un ou plusieurs ensembles de résultats, en fonction des besoins de la procédure stockée. Nous introduisons ici deux méthodes pour implémenter des procédures stockées afin de renvoyer des ensembles de résultats.

  1. Utilisez SYS_REFCURSOR

SYS_REFCURSOR est un type de données fourni par Oracle pour référencer l'ensemble de résultats. En utilisant SYS_REFCURSOR, une procédure stockée peut renvoyer un jeu de résultats et les applications clientes peuvent accéder et traiter le jeu de résultats.

Ce qui suit est un exemple d'utilisation de SYS_REFCURSOR pour renvoyer un ensemble de résultats :

CREATE OR REPLACE PROCEDURE sample_proc(
    p_param_1 IN VARCHAR2,
    p_param_2 IN OUT NUMBER,
    p_out_cur OUT SYS_REFCURSOR
)
IS
BEGIN
    OPEN p_out_cur FOR
    SELECT col_1, col_2, col_3
    FROM table_name
    WHERE column_name = p_param_1;

    p_param_2 := p_param_2 * 10;
END;

Dans cette procédure stockée, p_param_1 et p_param_2 sont des paramètres d'entrée et p_out_cur est le paramètre de sortie. La procédure stockée interrogera les données avec p_param_1 comme condition et stockera les résultats de la requête dans le paramètre p_out_cur de type SYS_REFCURSOR.

  1. Utilisation des curseurs

Une autre façon consiste à utiliser des curseurs. Un curseur est un mécanisme permettant de traiter un ensemble de résultats ligne par ligne. Lorsqu'une procédure stockée utilise un curseur pour renvoyer un jeu de résultats, elle peut parcourir le jeu de résultats ligne par ligne et renvoyer chaque ligne de données à l'application client.

Ce qui suit est un exemple d'utilisation d'un curseur pour renvoyer un ensemble de résultats :

CREATE OR REPLACE PROCEDURE sample_proc(
    p_param_1 IN VARCHAR2,
    p_param_2 IN OUT NUMBER
)
IS
    c_cursor SYS_REFCURSOR;
    v_col_1 table_name.col_1%TYPE;
    v_col_2 table_name.col_2%TYPE;
    v_col_3 table_name.col_3%TYPE;
BEGIN
    OPEN c_cursor FOR
    SELECT col_1, col_2, col_3
    FROM table_name
    WHERE column_name = p_param_1;

    LOOP
        FETCH c_cursor INTO v_col_1, v_col_2, v_col_3;
        EXIT WHEN c_cursor%NOTFOUND;

        -- 处理逐行返回的数据
    END LOOP;

    p_param_2 := p_param_2 * 10;

    CLOSE c_cursor;
END;

Dans cette procédure stockée, p_param_1 et p_param_2 sont des paramètres d'entrée. La procédure stockée interrogera les données en utilisant p_param_1 comme condition et utilisera le curseur pour parcourir chaque ligne de données. Pour chaque ligne de données, la procédure stockée peut utiliser des variables pour stocker les données de colonne de l'ensemble de résultats. La procédure stockée peut ensuite fermer le curseur à la fin à l'aide de l'instruction CLOSE.

3. Conclusion

La procédure stockée est l'une des fonctions importantes d'Oracle. Elle nous permet d'encapsuler un ensemble d'instructions SQL dans un bloc de code et de renvoyer un ou plusieurs ensembles de résultats. En utilisation réelle, vous pouvez choisir d'utiliser SYS_REFCURSOR ou un curseur pour renvoyer le jeu de résultats selon vos besoins. L’une ou l’autre approche nécessite l’écriture de code supplémentaire. Par conséquent, avant d'écrire une procédure stockée, assurez-vous que vous connaissez la documentation et les fonctions Oracle pertinentes et que vous pouvez les utiliser correctement pour répondre à vos besoins.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn