الانتقال إلى المحتوى الرئيسي
  • numbers() – تعيد جدولًا لا نهائيًا يحتوي على عمود number واحد (UInt64) يضم أعدادًا صحيحة بترتيب تصاعدي، بدءًا من 0. استخدم LIMITOFFSET اختياريًا) لتحديد عدد الصفوف.
  • numbers(N) – تعيد جدولًا يحتوي على عمود number واحد (UInt64) يضم أعدادًا صحيحة من 0 إلى N - 1.
  • numbers(N, M) – تعيد جدولًا يحتوي على عمود number واحد (UInt64) يضم M عددًا صحيحًا من N إلى N + M - 1.
  • numbers(N, M, S) – تعيد جدولًا يحتوي على عمود number واحد (UInt64) يضم قيمًا ضمن [N, N + M) بخطوة S (أي نحو M / S صفًا، مع التقريب للأعلى). يجب أن تكون S >= 1.
هذا مشابه لجدول النظام system.numbers. ويمكن استخدامه للاختبار وتوليد قيم متتابعة. الاستعلامات التالية متكافئة:
SELECT * FROM numbers(10);
SELECT * FROM numbers(0, 10);
SELECT * FROM numbers() LIMIT 10;
SELECT * FROM system.numbers LIMIT 10;
SELECT * FROM system.numbers WHERE number BETWEEN 0 AND 9;
SELECT * FROM system.numbers WHERE number IN (0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
تُعدّ الاستعلامات التالية مكافئة أيضًا:
SELECT * FROM numbers(10, 10);
SELECT * FROM numbers() LIMIT 10 OFFSET 10;
SELECT * FROM system.numbers LIMIT 10 OFFSET 10;
الاستعلامات التالية متكافئة أيضًا:
SELECT number * 2 FROM numbers(10);
SELECT (number - 10) * 2 FROM numbers(10, 10);
SELECT * FROM numbers(0, 20, 2);

أمثلة

أول 10 أعداد.
SELECT * FROM numbers(10);
 ┌─number─┐
 │      0 │
 │      1 │
 │      2 │
 │      3 │
 │      4 │
 │      5 │
 │      6 │
 │      7 │
 │      8 │
 │      9 │
 └────────┘
أنشئ تسلسلاً من التواريخ من 2010-01-01 إلى 2010-12-31.
SELECT toDate('2010-01-01') + number AS d FROM numbers(365);
اعثر على أول UInt64 >= 10^15 تكون في sipHash64(number) الخاصة به 20 بتًا صفريًا متتاليًا في النهاية.
SELECT number
FROM numbers()
WHERE number >= 1e15
  AND bitAnd(sipHash64(number), 0xFFFFF) = 0
LIMIT 1;
 ┌───────────number─┐
 │ 1000000000056095 │ -- 1.00 quadrillion
 └──────────────────┘

ملاحظات

  • لأسباب تتعلق بالأداء، إذا كنت تعرف عدد الصفوف التي تحتاج إليها، ففضّل الصيغ المقيّدة (numbers(N), numbers(N, M[, S])) على numbers() / system.numbers غير المقيّدة.
  • للتوليد المتوازي، استخدم numbers_mt(...) أو الجدول system.numbers_mt. لاحظ أن النتائج قد تُعاد بترتيب غير محدد.
آخر تعديل في ٢٥ يونيو ٢٠٢٦