الانتقال إلى المحتوى
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.

ارجو الرد: اضافة عموله لكل موظف حسب راتبه باستخدام CURSOR والمتغيرات

Featured Replies

بتاريخ:

مرحبا باخواني الاعزاء
ارجو حل السؤال التالي :
اضافة عموله لكل موظف حسب راتبه باستخدام CURSOR والمتغيرات
عن طريق ال UPDATE , عن طريق جدول EMP...........
مثلا
اي
ENTER_MIN(SAL)&
ENTER_MAX (SAL)&
ادخال الراتب يدوي

مثال
100
300
العموله هيه 5%
عن طريق ال UPDATE
اي من راتب 100 الى راتب 300 العموله هيه 5%
مابين 200 و 400 اريد لهم عموله 9%
وهكذذذذذا في كل مره

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

بتاريخ:

السلام عليكم ورحمة الله وبركاته
---------------------------------------
شوف كده ان شاء الله يكون الحل ده صحيح

CREATE OR REPLACE PROCEDURE RAISE_SALARY(MIN_SAL NUMBER,MAX_SAL NUMBER , BOUNSE NUMBER )
AS BEGIN FOR REC IN ( SELECT EMP_NO , SAL FROM EMP WHERE SAL BETWEEN MIN_SAL AND MAX_SAL  )
LOOP
UPDATE EMP 
SET    SAL=REC.SAL + ( BOUNSE / REC.SAL ) * 100 
WHERE EMP_NO=REC.EMP_NO;
END LOOP;
COMMIT;            
END;

بتاريخ:
  • كاتب الموضوع

شكرا على الحل
بس انا ما بدي اياه باستخدام PROCEDURE ولا loop
لاني لسا مبتدأ في الاوركل
ارجو حله باستخدام CURSOR و عن طريق ال UPDATE
ارجو انك فهمت قصدي
وشكرا لك...............

بتاريخ:

SET SERVEROUTPUT ON DECLARE
 CURSOR  deb_cursor iS
  SELECT SAL , EMPNO 
  from emp WHERE sal BETWEEN  &min_sal and &max_sal  ;
  v_sal    number(10,3) :=&SS ;
 x_EMPNO number(10);
f_sal  number(10,3);
x_sal number(10,3);
BEGIN v_sal  := v_sal   / 100;
 OPEN deb_cursor;
 LOOP
   FETCH deb_cursor INTO x_sal, x_EMPNO ;
f_sal := x_sal;
x_sal := v_sal  *  x_sal ;
f_sal := x_sal +  f_sal;
update emp set sal = f_sal
where EMPNO = x_EMPNO;
   EXIT WHEN deb_cursor%NOTFOUND;
   end loop ;
  CLOSE  deb_cursor;
end;


علما ان ss هى نسبه الزياده انا عملو بابسط طريقه لو فى حاجه مش فهامه انا تحت امرك

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

بتاريخ:

BEGIN FOR REC IN ( SELECT EMP_NO , SAL FROM EMP WHERE SAL BETWEEN :MIN_SAL AND :MAX_SAL  )
LOOP
UPDATE EMP 
SET    SAL=REC.SAL + ( :BOUNSE / REC.SAL ) * 100 
WHERE EMP_NO=REC.EMP_NO;

END LOOP;
COMMIT;
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.