« ORA-01422: chercher des rendements plus exact que le nombre demandé de lignes » Je reçois cette erreur lors de l'exécution de mon bloc

voix
0

Je wannt pour afficher 4 colonnes en utilisant le bloc PLSQL et je suis incapable d'exécuter le code que j'ai des suggestions de written.Any?

   DECLARE
    rsid    objectbase.asset_id%TYPE;
    obid    i18n_objectbase.object_id%TYPE;
    nme     i18n_objectbase.name%TYPE;
    descp   i18n_objectbase.short_description%TYPE;
BEGIN
    SELECT
        ob.asset_id,
        o.object_id,
        o.name,
        o.short_description
    INTO
        rsid,
        obid,
        nme,
        descp
    FROM
        objectbase        ob
        JOIN i18n_objectbase   o ON ( ob.object_id = o.object_id );

    dbms_output.put_line(rsid
                         || obid
                         || nme
                         || descp);
END;
/
Créé 24/10/2019 à 11:55
source utilisateur
Dans d'autres langues...                            


1 réponses

voix
0

Quelque chose comme ça ferait l'affaire mais je ne sais pas pourquoi vous aurez besoin de ce genre de code PL SQL (S'il vous plaît noter que je ne l'ai simplifié la partie où) ... voici:

DECLARE
   rsid    varchar2(100);
   obid    varchar2(100);
   nme     varchar2(100);
   descp   varchar2(100);

   cursor c_test
   is
   SELECT ob.asset_id
          , ob.object_id
          , ob.name
          , ob.short_description
   FROM objectbase ob;
BEGIN

   FOR i in c_test loop

      rsid := i.asset_id;
      obid := i.object_id;
      nme := i.name;
      descp := i.short_description;

      dbms_output.put_line(rsid
                        || obid
                        || nme
                        || descp);

   END LOOP;
END;

Voici la démo

Ensuite, utilisez ceci:

DECLARE
    rsid    varchar2(100);
    obid    varchar2(100);
    nme     varchar2(100);
    descp   varchar2(100);

BEGIN
    FOR i IN (SELECT  ob.asset_id
                      , ob.object_id 
                      , ob.name
                      , ob.short_description
              FROM objectbase ob) LOOP

       rsid := i.asset_id;
       obid := i.object_id;
       nme := i.name;
       descp := i.short_description;

       dbms_output.put_line(rsid
                         || obid
                         || nme
                         || descp);

    END LOOP;
END;
/

Voici la démo

Et voici le code avec vos tables et colonnes:

DECLARE
    rsid    objectbase.asset_id%TYPE;
    obid    i18n_objectbase.object_id%TYPE;
    nme     i18n_objectbase.name%TYPE;
    descp   i18n_objectbase.short_description%TYPE;
BEGIN

    FOR i IN (SELECT
        ob.asset_id,
        o.object_id,
        o.name,
        o.short_description
    FROM
        objectbase ob
        JOIN i18n_objectbase o ON ( ob.object_id = o.object_id )) loop

        rsid := i.asset_id;
        obid := i.object_id;
        nme := i.name;
        descp := i.short_description;

        dbms_output.put_line(rsid
                         || obid
                         || nme
                         || descp);
    END LOOP;
END;
Créé 24/10/2019 à 13:00
source utilisateur

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more