Modifying condition for PL/SQL procedure









up vote
0
down vote

favorite












I have a PL/SQL procedure for deleting records corresponding to a field having NULL value. Am able to achieve this by the below query.



set serveroutput on;

begin
dbms_output.put_line('Execution started');

for rec in (
select name from employee where emp_id is null
and location = 'SITE_A'
)
loop
delete from employeedetails@sitea where name = rec.name;
dbms_output.put_line('name '|| rec.name ||' deleted');
end loop;

dbms_output.put_line('Execution completed');
end;
/

set serveroutput off;


I am running the for loop query from one database and deleting the records in another database ( sitea ) using a database link.



I need to add a condition like, if the name=rec.name is not returning any records to be deleted,then dbms_output.put_line('No records to be deleted');



Is there a comfortable way to achieve it ?










share|improve this question



























    up vote
    0
    down vote

    favorite












    I have a PL/SQL procedure for deleting records corresponding to a field having NULL value. Am able to achieve this by the below query.



    set serveroutput on;

    begin
    dbms_output.put_line('Execution started');

    for rec in (
    select name from employee where emp_id is null
    and location = 'SITE_A'
    )
    loop
    delete from employeedetails@sitea where name = rec.name;
    dbms_output.put_line('name '|| rec.name ||' deleted');
    end loop;

    dbms_output.put_line('Execution completed');
    end;
    /

    set serveroutput off;


    I am running the for loop query from one database and deleting the records in another database ( sitea ) using a database link.



    I need to add a condition like, if the name=rec.name is not returning any records to be deleted,then dbms_output.put_line('No records to be deleted');



    Is there a comfortable way to achieve it ?










    share|improve this question

























      up vote
      0
      down vote

      favorite









      up vote
      0
      down vote

      favorite











      I have a PL/SQL procedure for deleting records corresponding to a field having NULL value. Am able to achieve this by the below query.



      set serveroutput on;

      begin
      dbms_output.put_line('Execution started');

      for rec in (
      select name from employee where emp_id is null
      and location = 'SITE_A'
      )
      loop
      delete from employeedetails@sitea where name = rec.name;
      dbms_output.put_line('name '|| rec.name ||' deleted');
      end loop;

      dbms_output.put_line('Execution completed');
      end;
      /

      set serveroutput off;


      I am running the for loop query from one database and deleting the records in another database ( sitea ) using a database link.



      I need to add a condition like, if the name=rec.name is not returning any records to be deleted,then dbms_output.put_line('No records to be deleted');



      Is there a comfortable way to achieve it ?










      share|improve this question















      I have a PL/SQL procedure for deleting records corresponding to a field having NULL value. Am able to achieve this by the below query.



      set serveroutput on;

      begin
      dbms_output.put_line('Execution started');

      for rec in (
      select name from employee where emp_id is null
      and location = 'SITE_A'
      )
      loop
      delete from employeedetails@sitea where name = rec.name;
      dbms_output.put_line('name '|| rec.name ||' deleted');
      end loop;

      dbms_output.put_line('Execution completed');
      end;
      /

      set serveroutput off;


      I am running the for loop query from one database and deleting the records in another database ( sitea ) using a database link.



      I need to add a condition like, if the name=rec.name is not returning any records to be deleted,then dbms_output.put_line('No records to be deleted');



      Is there a comfortable way to achieve it ?







      plsql oracle11g






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 11 at 10:58









      William Robertson

      8,00232233




      8,00232233










      asked Nov 9 at 16:16









      user9304804

      174




      174






















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          2
          down vote













          You can use the sql%rowcount implicit cursor attribute to see how many rows were affected by a DML statement; that works across a database link as well as locally:



          if sql%rowcount = 0 then
          dbms_output.put_line('No records to be deleted');
          else
          dbms_output.put_line('name '|| rec.name ||' deleted');
          end if;


          You can include it in the messages too:



          if sql%rowcount = 0 then
          dbms_output.put_line('name '|| rec.name ||': no records to be deleted');
          else
          dbms_output.put_line('name '|| rec.name ||': '|| sql%rowcount ||' record(s) deleted');
          end if;


          Then you'll see something like:



          Execution started
          name B: 1 record(s) deleted
          name C: no records to be deleted
          Execution completed


          PL/SQL procedure successfully completed.


          As name probably isn't unique you could encounter the same value twice as you go through your loop; in which case the first delete will find multiple rows and the second delete will find none. You could avoid the second one by adding distinct to your cursor query.



          And if you didn't want to see which names did and did not have remote data to delete then you could use a much simpler single delete, with no loop or PL/SQL, but it seems like this is an exercise anyway...






          share|improve this answer






















            Your Answer






            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "1"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53229455%2fmodifying-condition-for-pl-sql-procedure%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes








            up vote
            2
            down vote













            You can use the sql%rowcount implicit cursor attribute to see how many rows were affected by a DML statement; that works across a database link as well as locally:



            if sql%rowcount = 0 then
            dbms_output.put_line('No records to be deleted');
            else
            dbms_output.put_line('name '|| rec.name ||' deleted');
            end if;


            You can include it in the messages too:



            if sql%rowcount = 0 then
            dbms_output.put_line('name '|| rec.name ||': no records to be deleted');
            else
            dbms_output.put_line('name '|| rec.name ||': '|| sql%rowcount ||' record(s) deleted');
            end if;


            Then you'll see something like:



            Execution started
            name B: 1 record(s) deleted
            name C: no records to be deleted
            Execution completed


            PL/SQL procedure successfully completed.


            As name probably isn't unique you could encounter the same value twice as you go through your loop; in which case the first delete will find multiple rows and the second delete will find none. You could avoid the second one by adding distinct to your cursor query.



            And if you didn't want to see which names did and did not have remote data to delete then you could use a much simpler single delete, with no loop or PL/SQL, but it seems like this is an exercise anyway...






            share|improve this answer


























              up vote
              2
              down vote













              You can use the sql%rowcount implicit cursor attribute to see how many rows were affected by a DML statement; that works across a database link as well as locally:



              if sql%rowcount = 0 then
              dbms_output.put_line('No records to be deleted');
              else
              dbms_output.put_line('name '|| rec.name ||' deleted');
              end if;


              You can include it in the messages too:



              if sql%rowcount = 0 then
              dbms_output.put_line('name '|| rec.name ||': no records to be deleted');
              else
              dbms_output.put_line('name '|| rec.name ||': '|| sql%rowcount ||' record(s) deleted');
              end if;


              Then you'll see something like:



              Execution started
              name B: 1 record(s) deleted
              name C: no records to be deleted
              Execution completed


              PL/SQL procedure successfully completed.


              As name probably isn't unique you could encounter the same value twice as you go through your loop; in which case the first delete will find multiple rows and the second delete will find none. You could avoid the second one by adding distinct to your cursor query.



              And if you didn't want to see which names did and did not have remote data to delete then you could use a much simpler single delete, with no loop or PL/SQL, but it seems like this is an exercise anyway...






              share|improve this answer
























                up vote
                2
                down vote










                up vote
                2
                down vote









                You can use the sql%rowcount implicit cursor attribute to see how many rows were affected by a DML statement; that works across a database link as well as locally:



                if sql%rowcount = 0 then
                dbms_output.put_line('No records to be deleted');
                else
                dbms_output.put_line('name '|| rec.name ||' deleted');
                end if;


                You can include it in the messages too:



                if sql%rowcount = 0 then
                dbms_output.put_line('name '|| rec.name ||': no records to be deleted');
                else
                dbms_output.put_line('name '|| rec.name ||': '|| sql%rowcount ||' record(s) deleted');
                end if;


                Then you'll see something like:



                Execution started
                name B: 1 record(s) deleted
                name C: no records to be deleted
                Execution completed


                PL/SQL procedure successfully completed.


                As name probably isn't unique you could encounter the same value twice as you go through your loop; in which case the first delete will find multiple rows and the second delete will find none. You could avoid the second one by adding distinct to your cursor query.



                And if you didn't want to see which names did and did not have remote data to delete then you could use a much simpler single delete, with no loop or PL/SQL, but it seems like this is an exercise anyway...






                share|improve this answer














                You can use the sql%rowcount implicit cursor attribute to see how many rows were affected by a DML statement; that works across a database link as well as locally:



                if sql%rowcount = 0 then
                dbms_output.put_line('No records to be deleted');
                else
                dbms_output.put_line('name '|| rec.name ||' deleted');
                end if;


                You can include it in the messages too:



                if sql%rowcount = 0 then
                dbms_output.put_line('name '|| rec.name ||': no records to be deleted');
                else
                dbms_output.put_line('name '|| rec.name ||': '|| sql%rowcount ||' record(s) deleted');
                end if;


                Then you'll see something like:



                Execution started
                name B: 1 record(s) deleted
                name C: no records to be deleted
                Execution completed


                PL/SQL procedure successfully completed.


                As name probably isn't unique you could encounter the same value twice as you go through your loop; in which case the first delete will find multiple rows and the second delete will find none. You could avoid the second one by adding distinct to your cursor query.



                And if you didn't want to see which names did and did not have remote data to delete then you could use a much simpler single delete, with no loop or PL/SQL, but it seems like this is an exercise anyway...







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Nov 9 at 16:43

























                answered Nov 9 at 16:37









                Alex Poole

                129k6101176




                129k6101176



























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.





                    Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                    Please pay close attention to the following guidance:


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53229455%2fmodifying-condition-for-pl-sql-procedure%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

                    Edmonton

                    Crossroads (UK TV series)