طريقة للحصول على التاريخ دون الوقت من خلال الـ SQL !!

15 10 2008

هذا التابع وظيفته هو الحصول على التاريخ فقط دون الوقت (قيمة الوقت أصفار 00:00:00)

يفيد هذا التابع في العديد من الحالات أهمها عندما أجري مقارنة بين تاريخين فقط حيث أن الوقت لا يهمني على الإطلاق، فإنه سيؤدي إلى الحصول على بعض النتائج الخاطئة، وذلك نتيجة لمقارنة الوقت معه.

فمثلا لو أن لدي جدول للمستعيرين، وأردت الحصول على تقرير بأسماء جميع المستعيرين اللذين انتهت مدة اعارتهم ولنفرض أن التاريخ الكامل الآن من خلال التابع (الدالة) ()GetDate هي:

Select GetDate();

ليكن الناتج:

2007-06-21 12:26:24.807

 

ولنفرض أن لدي مستعير مسجل في الجدول تنتهي فترة إعارته في:

2007-06-21 12:35:24.807

لاحظ الفرق هو دقائق معدودة فقط فإن ناتج الاستعلام الناتج عند مقارنة حقل تاريخ انتهاء الإعارة مع التابع GetDate() لن يظهر هذا المستعير (أعود و أذكر بأن الوقت لا يهمني وإنما يهمني فقط التاريخ)، فلحل هذه المشكلة تستخدم التابع التالي:

GetDateOnly(DateTime @DateTime);

وهو على الشكل التالي:

set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
– =============================================
– Author:        Abdulkarim Kanaan
– Create date:   4/6/2007
– Description:   للحصول على التاريخ فقط دون الوقت
– =============================================
CREATE FUNCTION [dbo].[GetDateOnly]
(
      – Add the parameters for the function here 
      @DateTime DateTime
)
RETURNS smalldatetime
AS
BEGIN
      – Declare the return variable here
      DECLARE @Result smalldatetime

      Select @DateTime = DateAdd(hh, -DatePart(hh, @DateTime), @DateTime);
      Select @DateTime = DateAdd(mi, -DatePart(mi, @DateTime), @DateTime);
      Select @DateTime = DateAdd(ss, -DatePart(ss, @DateTime), @DateTime);
      Select @DateTime = DateAdd(ms, -DatePart(ms, @DateTime), @DateTime);

      – Add the T-SQL statements to compute the return value here

      Select @Result = @DateTime

      – Return the result of the function
      RETURN @Result 
END

 

 

 

طبعا الفكرة بأنني قمت بإيجاد أجزاء الوقت (الساعة، الدقائق، الثواني، أجزاء الثواني) على الترتيب من التاريخ وطرحها منه.

 

 

 


الإجراءات

معلومات

2 ردود

6 02 2009
alnabhani

فكرة جميلة منك ، والاجمل انها تعتمد على تابع في قاعدة البيانات وليس لغة البرمجة C# ليكون افضل واسرع

دائما تتحفنا

بارك الله فيك

7 02 2009
عبد الكريم كنعان

شكرا على مرورك أخي النبهاني,,

أضف تعليق