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

Stored Procedure Expert

Featured Replies

بتاريخ:

السلام عليكم ورحمة الله وبركاته

أرجو مساعدتى فى هذا الكود

هذا الكود هو كود سيكول سيرفير و المطلوب تحويله إلى كود PL/SQL

طبعاً هناك عدة مشاكل فى تحويل الكود مثال لا يمكن فى الاوراكل اعطاء قيمة للديسمال فى الباراميتر

و هناك مشكله أخرى فيوجد فى السيكول سيرفر داله تقوم بعمل فحص للقيمة إذا كانت رقم أو لا IsNumeric 

بينما ذلك غير موجود فى الأوراكل ....

هل من مقترحات يا أصحاب الخبرة ؟؟

/****** Object:  StoredProcedure [dbo].[etl_convertToNumeric]     ******/


/*
  Description :  Return default value 1 when  can't convert String Value to Numeric
  :*/
---------------------------------------------------------------------------------------


CREATE PROCEDURE [dbo].[etl_convertToNumeric] 
DecimalPosition Int@,
(StringValue VarChar(20@,
NumericValue  Decimal(15,3) OUTPUT@,
Error  Int OUTPUT@
AS
Declare  @DividedBy Int


;SET @Error = 0


 Verify that the input text field is available-- 


('%IF (@StringValue != '%NA%' AND @StringValue != '%BLANK


BEGIN
IF  (IsNumeric(@StringValue) = 0)


BEGIN
SET @Error = 1  -- Value can't be converted 
(PRINT 'Error: Could not convert string (' + @StringValue + ' to Decimal(15,3) format'
END


ELSE
(IF  (@DecimalPosition != 0)
BEGIN
((SET @DividedBy       = Convert(Int, '1' + Replicate('0', @DecimalPosition
(SET @NumericValue = Convert(Decimal(15,3), @StringValue
SET @NumericValue = @NumericValue / @DividedBy
END


ELSE
BEGIN
(SET @NumericValue = Convert(Decimal(15,3), @StringValue
END
END


ELSE
BEGIN
-- Set  the returned numerical value to -9999 to indicate that the field is not available--
; SET @NumericValue = -9999
  ; SET @NumericValue = 0
END

تم تعديل بواسطة Ahmad.Hasan

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

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

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

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

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

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.