هذا التابع وظيفته هو الحصول على التاريخ فقط دون الوقت (قيمة الوقت أصفار 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
– Return the result of the function
RETURN @Result
END
طبعا الفكرة بأنني قمت بإيجاد أجزاء الوقت (الساعة، الدقائق، الثواني، أجزاء الثواني) على الترتيب من التاريخ وطرحها منه.
فكرة جميلة منك ، والاجمل انها تعتمد على تابع في قاعدة البيانات وليس لغة البرمجة C# ليكون افضل واسرع
دائما تتحفنا
بارك الله فيك
شكرا على مرورك أخي النبهاني,,