الانتقال إلى المحتوى الرئيسي
مجموعة أنواع البيانات التي تمثل الفواصل الزمنية للتاريخ والوقت. وهي الأنواع الناتجة عن العامل INTERVAL. البنية:
  • فاصل زمني ممثل بقيمة عدد صحيح غير موقّع.
  • نوع الفاصل الزمني.
أنواع الفواصل الزمنية المدعومة:
  • NANOSECOND
  • MICROSECOND
  • MILLISECOND
  • SECOND
  • MINUTE
  • HOUR
  • DAY
  • WEEK
  • MONTH
  • QUARTER
  • YEAR
لكل نوع من أنواع الفواصل الزمنية نوع بيانات منفصل. على سبيل المثال، يقابل الفاصل الزمني DAY نوع البيانات IntervalDay:
SELECT toTypeName(INTERVAL 4 DAY)
┌─toTypeName(toIntervalDay(4))─┐
│ IntervalDay                  │
└──────────────────────────────┘

ملاحظات حول الاستخدام

يمكنك استخدام القيم من النوع Interval في العمليات الحسابية مع القيم من النوع Date وDateTime. على سبيل المثال، يمكنك إضافة 4 أيام إلى الوقت الحالي:
SELECT now() AS current_date_time, current_date_time + INTERVAL 4 DAY
┌───current_date_time─┬─plus(now(), toIntervalDay(4))─┐
│ 2019-10-23 10:58:45 │           2019-10-27 10:58:45 │
└─────────────────────┴───────────────────────────────┘
كما يمكن أيضًا استخدام عدة فواصل زمنية في الوقت نفسه:
SELECT now() AS current_date_time, current_date_time + (INTERVAL 4 DAY + INTERVAL 3 HOUR)
┌───current_date_time─┬─plus(current_date_time, plus(toIntervalDay(4), toIntervalHour(3)))─┐
│ 2024-08-08 18:31:39 │                                                2024-08-12 21:31:39 │
└─────────────────────┴────────────────────────────────────────────────────────────────────┘
ولمقارنة القيم ذات الفواصل الزمنية المختلفة:
SELECT toIntervalMicrosecond(3600000000) = toIntervalHour(1);
┌─less(toIntervalMicrosecond(179999999), toIntervalMinute(3))─┐
│                                                           1 │
└─────────────────────────────────────────────────────────────┘

الفواصل الزمنية المختلطة النوع

يمكن إنشاء فواصل زمنية مختلطة النوع، مثل عدة ساعات وعدة دقائق، باستخدام البنية INTERVAL 'value' <from_kind> TO <to_kind>. وتكون النتيجة قيمة من النوع Tuple تتكوّن من فاصلين زمنيين أو أكثر. التركيبات المدعومة:
الصياغةتنسيق السلسلةمثال
YEAR TO MONTHY-MINTERVAL '2-6' YEAR TO MONTH
DAY TO HOURD HINTERVAL '5 12' DAY TO HOUR
DAY TO MINUTED H:MINTERVAL '5 12:30' DAY TO MINUTE
DAY TO SECONDD H:M:SINTERVAL '5 12:30:45' DAY TO SECOND
HOUR TO MINUTEH:MINTERVAL '1:30' HOUR TO MINUTE
HOUR TO SECONDH:M:SINTERVAL '1:30:45' HOUR TO SECOND
MINUTE TO SECONDM:SINTERVAL '5:30' MINUTE TO SECOND
يُتحقَّق من الحقول غير الأولى وفقًا لمعيار SQL: MONTH من 0 إلى 11، وHOUR من 0 إلى 23، وMINUTE من 0 إلى 59، وSECOND من 0 إلى 59.
SELECT INTERVAL '1:30' HOUR TO MINUTE;
┌─(toIntervalHour(1), toIntervalMinute(30))─┐
│ (1,30)                                     │
└────────────────────────────────────────────┘
تسري علامة بادئة اختيارية + أو - على جميع المكوّنات:
SELECT INTERVAL '+1:30' HOUR TO MINUTE;
-- this is equivalent to:
-- SELECT INTERVAL '1:30' HOUR TO MINUTE;
┌─(toIntervalHour(1), toIntervalMinute(30))─┐
│ (1,30)                                     │
└────────────────────────────────────────────┘

انظر أيضًا

آخر تعديل في ٢٥ يونيو ٢٠٢٦