بتاريخ: 6 فبراير 201412 سنة comment_246330 السلام عليكم ورحمة الله وبركاته أرجو مساعدتى فى هذا الكود هذا الكود هو كود سيكول سيرفير و المطلوب تحويله إلى كود 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 تم تعديل 6 فبراير 201412 سنة بواسطة Ahmad.Hasan تقديم بلاغ
انضم إلى المناقشة
يمكنك المشاركة الآن والتسجيل لاحقاً. إذا كان لديك حساب, سجل دخولك الآن لتقوم بالمشاركة من خلال حسابك.