الانتقال إلى المحتوى
View in the app

A better way to browse. Learn more.

مجموعة مستخدمي أوراكل العربية

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

مشكله في كيرسور

Featured Replies

بتاريخ:

بسم الله الرحمن الرحيم


عندي مشكلة هي اني عندما اقوم بعمل سيلكت لمجموعة من recordsبناء على رقم معين وعند عمل insertفي block ومن ثم حفظها في الداتا بيز يقوم بعمل insert لريكورد واحد فقط مع العلم انه على التود او تنفيذ السلكت على السيكول يسترجع كل الريكورد المطلوبة سواء كان ريكورد واحد او اكثر

ما هو التعديل المطلوب لجعل هذا cursor يسترجع كل الريكرود ويقوم بعمل insertفي block






declare

v_GRP_COMP_ID HAB_CONT_ME_BOUND.GRP_COMP_ID%type;

v_BUILD_CONT_ID HAB_CONT_ME_BOUND.BUILD_CONT_ID%type;

v_USER_BAND_ID HAB_CONT_ME_BOUND.USER_BAND_ID%type;

v_MENTENCE_BAND HAB_CONT_ME_BOUND.MENTENCE_BAND%type;

cursor emp_cursor is

SELECT GRP_COMP_ID,

BUILD_CONT_ID,

USER_BAND_ID,

MENTENCE_BAND

FROM HAB_CONT_ME_BOUND

WHERE BUILD_CONT_ID=:HAB_BUILD_CONT_MENTCE.BUILD_CONT_ID;

begin

open emp_cursor;

loop

fetch emp_cursor into v_GRP_COMP_ID, v_BUILD_CONT_ID, v_USER_BAND_ID, v_MENTENCE_BAND;

:HAB_BUILD_CONT_MENTCE_D.GRP_COMP_ID:=v_GRP_COMP_ID;

:HAB_BUILD_CONT_MENTCE_D.BAND_ID:=band_id_sEQ.NEXTVAL;

:HAB_BUILD_CONT_MENTCE_D.USER_BAND_ID:=v_USER_BAND_ID;

:HAB_BUILD_CONT_MENTCE_D.BAND_NAME:=v_MENTENCE_BAND;

:HAB_BUILD_CONT_MENTCE_D.BUILD_CONT_ID_MENTCE:=v_BUILD_CONT_ID;

exit when emp_cursor%notfound;

end loop;

end;


شكرا وجزاكم الله خيرررررررا

بتاريخ:

السلام عليكم
جرب هذا الكود:

 Declare
 V_Grp_Comp_Id Hab_Cont_Me_Bound.Grp_Comp_Id%Type;
 V_Build_Cont_Id Hab_Cont_Me_Bound.Build_Cont_Id%Type;
 V_User_Band_Id Hab_Cont_Me_Bound.User_Band_Id%Type;
 V_Mentence_Band Hab_Cont_Me_Bound.Mentence_Band%Type;

 Cursor Emp_Cursor Is
 Select Grp_Comp_Id,
        Build_Cont_Id,
        User_Band_Id,
        Mentence_Band
   From Hab_Cont_Me_Bound
  Where Build_Cont_Id =: Hab_Build_Cont_Mentce.Build_Cont_Id;

Begin
 For Rec In Emp_Cursor Loop
  :Hab_Build_Cont_Mentce_D.Grp_Comp_Id          := Rec.V_Grp_Comp_Id;
  :Hab_Build_Cont_Mentce_D.Band_Id              := Band_Id_Seq.Nextval;
  :Hab_Build_Cont_Mentce_D.User_Band_Id         := Rec.V_User_Band_Id;
  :Hab_Build_Cont_Mentce_D.Band_Name            := Rec.V_Mentence_Band;
  :Hab_Build_Cont_Mentce_D.Build_Cont_Id_Mentce := Rec.V_Build_Cont_Id;
 End Loop;
End;



بالتوفيق.

بتاريخ:




جرب أن تضع Commit قبل end loop

وان شاء الله تمشى معاك



بالتوفيق ان شاءالله

تم تعديل بواسطة ENG_HOSSAM_WALLY

بتاريخ:

المشكله ان الcursor يسجل القيم على ريكورد واحد و لحلها تقوم بوضع كود داخل اللوب يقوم بادراج سجل جديد عند دورا ن اللوب كما يلي:

declare

v_GRP_COMP_ID HAB_CONT_ME_BOUND.GRP_COMP_ID%type;

v_BUILD_CONT_ID HAB_CONT_ME_BOUND.BUILD_CONT_ID%type;

v_USER_BAND_ID HAB_CONT_ME_BOUND.USER_BAND_ID%type;

v_MENTENCE_BAND HAB_CONT_ME_BOUND.MENTENCE_BAND%type;

cursor emp_cursor is

SELECT GRP_COMP_ID,

BUILD_CONT_ID,

USER_BAND_ID,

MENTENCE_BAND

FROM HAB_CONT_ME_BOUND

WHERE BUILD_CONT_ID=:HAB_BUILD_CONT_MENTCE.BUILD_CONT_ID;

begin

open emp_cursor;

loop

fetch emp_cursor into v_GRP_COMP_ID, v_BUILD_CONT_ID, v_USER_BAND_ID, v_MENTENCE_BAND;

exit when emp_cursor%notfound;

last_record;
next_record;

:HAB_BUILD_CONT_MENTCE_D.GRP_COMP_ID:=v_GRP_COMP_ID;

:HAB_BUILD_CONT_MENTCE_D.BAND_ID:=band_id_sEQ.NEXTVAL;

:HAB_BUILD_CONT_MENTCE_D.USER_BAND_ID:=v_USER_BAND_ID;

:HAB_BUILD_CONT_MENTCE_D.BAND_NAME:=v_MENTENCE_BAND;

:HAB_BUILD_CONT_MENTCE_D.BUILD_CONT_ID_MENTCE:=v_BUILD_CONT_ID;

end loop;

end; 

انضم إلى المناقشة

يمكنك المشاركة الآن والتسجيل لاحقاً. إذا كان لديك حساب, سجل دخولك الآن لتقوم بالمشاركة من خلال حسابك.

زائر
أضف رد على هذا الموضوع...

برجاء الإنتباه

بإستخدامك للموقع فأنت تتعهد بالموافقة على هذه البنود: سياسة الخصوصية

Account

Navigation

البحث

إعداد إشعارات المتصفح الفورية

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.