Electronic Gilgamesh
عزيزي الزائر كما هو واضح بأنك زائر للمنتدى لذى نود ان ندعوك الى الدخول ان كانت لديك عضوية او التسجيل في المنتدى نتشرف بتواجدك معنا حيث المعلومة الجديدة والدروس التعليمية الحصرية

انضم إلى المنتدى ، فالأمر سريع وسهل

Electronic Gilgamesh
عزيزي الزائر كما هو واضح بأنك زائر للمنتدى لذى نود ان ندعوك الى الدخول ان كانت لديك عضوية او التسجيل في المنتدى نتشرف بتواجدك معنا حيث المعلومة الجديدة والدروس التعليمية الحصرية
Electronic Gilgamesh
هل تريد التفاعل مع هذه المساهمة؟ كل ما عليك هو إنشاء حساب جديد ببضع خطوات أو تسجيل الدخول للمتابعة.

دوال الوقت والتاريخ الجديدة المضافة بـ sql server 2012

اذهب الى الأسفل

دوال الوقت والتاريخ الجديدة المضافة بـ sql server 2012 Empty دوال الوقت والتاريخ الجديدة المضافة بـ sql server 2012

مُساهمة من طرف Admin الجمعة سبتمبر 14, 2012 12:09 am

السلام عليكم ورحمة الله وبركاته
اعود اليكم اليوم وغايتي هو تسليط الضوء على المستجدات الجديدة في نسخة السيكوال سيرفر 2012 ,ويسعدني بأن اكون اول من اكتب مقال وباللغة العربية عن تلك الميزات .وحتى في المواقع الانكليزية فذكر تلك الخصائص والميزات يكاد يكون قليل,
أمتازت هذه النسخة القادمة بأمكانيات وميزات لربما مميزة في مسار المطورين والذكاء المهني والأدريين (Developer ,Business intelligence,Administrator)
..
ومن هذه الدوال الجديدة المضافة للغة البرمجة T-sql هي دوال التعامل مع الوقت والتاريخ حيث تستخدم للحصول على التاريخ والوقت من خلال اجزاء تجمع وتشكيلها بالصيغة المعروفة,
طيب لربما تتذكر جيدآ اننا كنا نستخدم الدالة Datepart لأستخلاص اجزاء التاريخ والوقت واسنادها لمتغيرات ,الدوال الجديدة تقوم عكس هذه الدالة بالضبط,

دعونا الان نخوض في تلك الدوال الجديدة ونشرحها ونذكر لكل دالة مثال عن كيفية تطبيقها
دالة DATEFROMPARTS
هي دالة جديدة اضيفت في النسخة الجديدة من السيكوال سيرفر 2012 ونسخة Denali.لذى اذا لم تكن قد قمت بتنصيب نسخة 2012 فلن تستطيع تطبيق المثال التالي حول كيفية استخدام هذه الدالة
مع العلم ان هذه الدالة هي من الدوال التابعة للنظام,
حيث تقوم بأرجاع التاريخ وبصيغ واجزاءه بعد ان نخصص اليوم والشهر والسنة عبر متغيرات لكل جزء
اي متغير للسنة ومتغير للشهر ومتغير لليوم ,وبعد ذلك تقوم هذه الدالة بتحويل هذه المتغيرات لصيغة
Date مع الملاحظة ان التنسيق سوف يأخذ التنسيق الافتراضي الذي قمت بأعداده على السيرفر

مثال على ذلك اقرء الكود البرمجي التالي


الكود:
DECLARE
  @YearPart  INT = 2012
, @MonthPart INT = 06
, @Daypart  INT = 04


SELECT DATEFROMPARTS (@YearPart, @MonthPart, @Daypart) AS [ Data Using DATEFROMPARTS Function]
GO

النتائج سوف تظهر التالي
04-06-2012




2-دالة TIMEFROMPARTS
دالة جديدة اضيفت في نسخة السيكوال سيرفر 2012 تقوم بأرجاع الوقت من خلال متغيرات تمثل
اجزاء الوقت مثل ما وضحنا ذلك في المثال السابق ,اما الصيغة القياسية لتلك الدالة فتكون بالشكل التالي
TIMEFROMPARTS (HOUR Part, MINUTE part, SECONDS Part, FRACTIONS, PRECISION)
حيث ان :
1- HOUR Part, MINUTE part, SECONDS Partهي متغيرات او ثوابت تمثل اجزاء الوقت
2- fractions : هي عبارة عن نسب تمثل اجزاء الثواني وحيث انها تعتمد على قيمة PRECISION في تحديد مقدار تلك النسبة
• لو كانت قيمة fractions تساوي 3 وقيمة الــ PRECISION تساوي 1 فسوف تظهر اجزاء الثواني بالشكل التالي 0.3
• لو كانت قيمة fractions تساوي 30 وقيمة الــ PRECISION تساوي 2 فسوف تظهر اجزاء الثواني بالشكل التالي 0.30
• لو كانت قيمة fractions تساوي 300 وقيمة الــ PRECISION تساوي 3 فسوف تظهر اجزاء الثواني بالشكل التالي 0.300
اي نستدل ان PRECISION تمثل عدد الارقام العشرية بعد الفارزة
دعونا نكتب الكود البرمجي التالي لتتضح لنا الدالة


الكود:
DECLARE
  @HOURPart    INT = 03
, @MINUTEPart  INT = 33
, @SECONDSPart INT = 33


SELECT
 TIMEFROMPARTS (@HOURPart, @ MINUTEPart, @SECONDSPart, 300, 3)
 AS [Data Using TIMEFROMPARTS Function]
GO




النتائج التي سوف تظهر لنا هي :

03:33:33.300


3-دالة DATETIMEFROMPARTS
هي عبارة عن دالة جديدة في النسخة الجديدة من السيكوال سيرفر 2012 تقوم بأرجاع التاريخ والوقت عن طريق تمرير لها اجزاءها المطلوبة كما في الدوال السابقة ,الصيغة القياسية لها هي كالتالي


الكود:
DATETIME2FROMPARTS (YEARPart, MONTHPart, DAYPart, HOURPart, MINUTEPart, SECONDS, MILLISECONDS)



لن يكون هناك الحاجة لذكر الكود البرمجي الخاص بهذه الدالة لأنها واضحة ويمكن ان تجمع الاكواد البرمجية السابقة بهذه الدالة,الفرق الوحيد اننا هنا يجب ان نمرر الـ Milliseconds Parameter

4-دالة DATETIME2FROMPARTS

هي عبارة عن دالة اضيفت في النسخة الجديدة من السيكوال سيرفر 2012 تقوم هذه الدالة بأرجاع الوقت والتاريخ بشكل نوع البيانات
DateTime2 من خلال اسناد لها اجزاء التاريخ والوقت عبر متغيرات او ثوابت , الصيغة القياسية لكتابة هذه الدالة هي


الكود:
DATETIME2FROMPARTS (YEAR, MONTH, DAY, HOUR, MINUTE, SECONDS, FRACTIONS, PRECISION)



كذلك هنا لن نذكر مثال للكود البرمجي لأن الصيغة واضحة جدآ.

دالة SMALLDATETIMEFROMPARTS

5- دالة SMALLDATETIMEFROMPARTS
دالة جديدة اضيفت في نسخة السيكوال سيرفر 2012 تقوم هذه الدالة بأرجاع الوقت والتاريخ بشكل نوع البيانات
SmallDateTime من خلال اسناد لها اجزاء التاريخ والوقت عبر متغيرات او ثوابت , الصيغة القياسية لكتابة هذه الدالة هي


الكود:
SMALLDATETIMEFROMPARTS (YEAR, MONTH, DAY, HOUR, MINUTE)




6-دالة DATETIMEOFFSETFROMPARTS
دالة جديدة اضيفت في نسخةالسيكوال سيرفر 2012 تقوم هذه الدالة بأرجاع الوقت والتاريخ بشكل نوع البيانات datetimeoffset
هنا اختلاف بسيط هو اننا سوف نقوم بتمرير متغير جديد يمثل مقدار الـ offset وهو ببساطة يمثل مقدار الفرق بين مناطق الزمن
Time Zone بالساعات والدقايق , الصيغة القياسية لهذه الدالة هي :


الكود:
DATETIMEOFFSETFROMPARTS (YEARPart, MONTHPart, DAYPart, HOURPart, MINUTEPart, SECONDSPart,
      FRACTIONS, HOUR_OFFSET, MINUTE_OFFSET, PRECISION)



المثال التالي سوف يوضح ذلك وبشكل اكثر دقة.

الكود:

DECLARE
  @YEARPart    INT = 2012
, @MONTHPart  INT = 06
, @DAYPart    INT = 04
, @HOURPart    INT = 04
, @MINUTEPart  INT = 04
, @SECONDSPart INT = 55


SELECT
 DATETIMEOFFSETFROMPARTS (@YEARPart, @MONTHPart, @DAYPart, @HOURPart, @MINUTEPart,@SECONDSPart,300, 3, 30, 3)
 AS [Retrieved Data Using DATETIMEOFFSETFROMPARTS Function]
GO


النتائج التي سوف تظهر سوف تكون بالشكل التالي

2012-06-04 04:04:55.300 +03:30



7-دالة EOMONTH

دالة جديدة اضيفت في النسخة الجديدة من السيكوال سيرفر 2012,بصراحة منذ اول وهلة وأطلاعي على هذه الدالة اعجبت بها جدآ
حب من اول نظرة او كما نقول بالعراقي (حب من اول بوعة Razz) ,عالعموم تعتبر هذه الدالة هي دالة حسابية اكثر من هي دالة تعامل مع الوقت حيث تقوم بحساب وايجاد اخر يوم من الشهر بالاعتماد على القيم التي ادخلناها ومررناها للدالة ,الصيغة القياسية لهذه الدالة هي:

الكود:

EOMONTH (START_DATE, [, MONTH_TO_ADD ])




كما في المثال البرمجي التالي

الكود:

DECLARE
 @STARTDATE DATETIME = GETDATE ()


SELECT EOMONTH (@STARTDATE) AS [This Month Last Day]
SELECT EOMONTH (@STARTDATE, 1) AS [Next Month Last Day]
SELECT EOMONTH (@STARTDATE, -1) AS [Last Month Last Day]
GO




النتائج التي سوف تظهر ستكون بالشكل التالي :
للجملة الاستعلام الاولى :


This Month Last Day
__________________________
2012-01-31 00:00:00.000




لجملة الاستعلام الثانية :
Next Month Last Day
-----------------------
2012-02-29 00:00:00.000

ولجملة الاستعلام الثالثة :


Last Month Last Day
-----------------------
2011-12-31 00:00:00.000




Admin
Admin
Admin

عدد الرسائل : 117
تاريخ التسجيل : 02/09/2008

https://iteg.forum.st

الرجوع الى أعلى الصفحة اذهب الى الأسفل

الرجوع الى أعلى الصفحة

- مواضيع مماثلة

 
صلاحيات هذا المنتدى:
لاتستطيع الرد على المواضيع في هذا المنتدى