Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

चुनिंदा . में मिनटों की रेंज बनाएं (15)

यदि आप किसी दिनांक मान से प्रारंभ कर रहे हैं, या इस मामले में कोई मान जिसे दिनांक में परिवर्तित कर दिया गया है, तो आप पा सकते हैं कि यह दिन का कौन-सा 15 मिनट का ब्लॉक है जो मध्यरात्रि के बाद सेकंड की संख्या में हेर-फेर कर रहा है; जिसे आप to_char() . से प्राप्त कर सकते हैं SSSSS . के साथ प्रारूप मॉडल।

select to_char(sysdate, 'YYYY-MM-DD HH24:MI:SS') as now_time,
  to_char(sysdate, 'SSSSS') as now_secs
from dual;

NOW_TIME            NOW_S
------------------- -----
2015-06-18 18:25:49 66349

आप 900 (15 * 60) से विभाजित करके, एक पूर्णांक मान प्राप्त करने के लिए इसे छोटा करके या फ़्लोरिंग करके, और 900 से वापस गुणा करके सेकंड की संख्या को 15-मिनट की अवधि की शुरुआत तक पूर्णांक बना सकते हैं:

select to_char(sysdate, 'YYYY-MM-DD HH24:MI:SS') as now_time,
  to_char(sysdate, 'SSSSS') as now_secs,
  to_number(to_char(sysdate, 'SSSSS'))/900 as calc1,
  floor(to_number(to_char(sysdate, 'SSSSS'))/900) as calc2,
  floor(to_number(to_char(sysdate, 'SSSSS'))/900) * 900 as calc3
from dual;

NOW_TIME            NOW_S      CALC1      CALC2      CALC3
------------------- ----- ---------- ---------- ----------
2015-06-18 18:25:49 66349 73.7211111         73      65700

और आप इसे वापस किसी तिथि में जोड़कर एक समय में परिवर्तित कर सकते हैं:

select to_char(sysdate, 'YYYY-MM-DD HH24:MI:SS') as now_time,
  to_char(sysdate, 'SSSSS') as now_secs,
  floor(to_number(to_char(sysdate, 'SSSSS'))/900) * 900 as calc3,
  to_char(date '1970-01-01'
    + (floor(to_number(to_char(sysdate, 'SSSSS'))/900) * 900 / 86400),
    'HH24:MI:SS') as calc4
from dual;

NOW_TIME            NOW_S      CALC3 CALC4  
------------------- ----- ---------- --------
2015-06-18 18:25:49 66349      65700 18:15:00

हालांकि आप शायद तारीख को सुरक्षित रखना चाहते हैं, इसलिए आप इसे trunc(<original_date>) में जोड़ सकते हैं बजाय। जब तक आपके पास केवल एक ही दिन के भीतर डेटा नहीं है, या एक साथ कई दिनों से एक ही समय दिखाना चाहते हैं, मुझे लगता है।

यहां 10 यादृच्छिक रूप से जेनरेट किए गए समय के साथ एक डेमो दिया गया है, जिसमें उन्हें 15 मिनट का ब्लॉक दिया गया है:

with t (date_field) as (
  select sysdate - dbms_random.value(0, 1)
  from dual
  connect by level <= 10
)
select to_char(date_field, 'YYYY-MM-DD HH24:MI:SS') as datefield,
  to_char(date_field, 'SSSSS') as time_secs,
  floor(to_number(to_char(date_field, 'SSSSS'))/900) * 900
    as fifteen_min_block_secs,
  to_char(trunc(date_field)
    + (floor(to_number(to_char(date_field, 'SSSSS'))/900) * 900) / 86400,
    'YYYY-MM-DD HH24:MI:SS') as fifteen_min_block
from t
order by datefield;

DATEFIELD           TIME_ FIFTEEN_MIN_BLOCK_SECS FIFTEEN_MIN_BLOCK 
------------------- ----- ---------------------- -------------------
2015-06-17 21:03:00 75780                  75600 2015-06-17 21:00:00
2015-06-18 05:07:28 18448                  18000 2015-06-18 05:00:00
2015-06-18 05:48:42 20922                  20700 2015-06-18 05:45:00
2015-06-18 07:23:03 26583                  26100 2015-06-18 07:15:00
2015-06-18 08:24:57 30297                  29700 2015-06-18 08:15:00
2015-06-18 08:52:06 31926                  31500 2015-06-18 08:45:00
2015-06-18 10:59:14 39554                  38700 2015-06-18 10:45:00
2015-06-18 11:47:05 42425                  42300 2015-06-18 11:45:00
2015-06-18 12:08:37 43717                  43200 2015-06-18 12:00:00
2015-06-18 17:07:23 61643                  61200 2015-06-18 17:00:00

तो आपको

. की आवश्यकता होगी
trunc(date_field)
  + (floor(to_number(to_char(date_field, 'SSSSS'))/900) * 900) / 86400

या थोड़ा आसान

trunc(date_field)
  + floor(to_number(to_char(date_field, 'SSSSS'))/900) / 96

अपने group by . में भाग लें खंड, और शायद प्रदर्शन के लिए आपकी चयन सूची में।

यह मानते हुए कि T2318.C3 युग से सेकंड है, आप इसे सीधे जोड़ सकते हैं और फिर इसे अपने secs_to_datetime पर भेज सकते हैं समारोह:

secs_to_datetime(floor(T2318.C3 / 900) * 900)

तो एक सीटीई में दस यादृच्छिक रूप से जेनरेट किए गए समय के साथ, ऊपर वाले के बराबर डेमो होगा:

with T2318(c3) as (
  select 1434708000 - dbms_random.value(0, 80000) from dual
  connect by level <= 10
)
select to_char(secs_to_datetime(T2318.C3),'DD/MM/YYYY HH24:MI:SS') as datefield,
  T2318.C3 as time_secs,
  floor(T2318.C3/900) * 900 as fifteen_min_secs,
  to_char(secs_to_datetime(floor(T2318.C3 / 900) * 900),
    'DD/MM/YYYY HH24:MI:SS') as fifteen_min
from T2318
order by T2318.C3;

DATEFIELD              TIME_SECS FIFTEEN_MIN_SECS FIFTEEN_MIN       
------------------- ------------ ---------------- -------------------
18/06/2015 12:34:02   1434630842       1434630600 18/06/2015 12:30:00
18/06/2015 15:06:25   1434639985       1434639600 18/06/2015 15:00:00
18/06/2015 16:43:27   1434645807       1434645000 18/06/2015 16:30:00
18/06/2015 18:57:25   1434653845       1434653100 18/06/2015 18:45:00
18/06/2015 19:01:09   1434654069       1434654000 18/06/2015 19:00:00
18/06/2015 20:54:09   1434660849       1434660300 18/06/2015 20:45:00
19/06/2015 03:59:48   1434686388       1434685500 19/06/2015 03:45:00
19/06/2015 06:58:09   1434697089       1434696300 19/06/2015 06:45:00
19/06/2015 07:36:36   1434699396       1434699000 19/06/2015 07:30:00
19/06/2015 07:47:26   1434700046       1434699900 19/06/2015 07:45:00

या अगर यह मिलीसेकंड में है, तो 900000 से भाग दें और गुणा करें।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. डेटाबेस में सकर्मक निर्भरता को हल करने के लिए SQL क्वेरी

  2. Oracle में अस्थायी तालिकाओं के विकल्प

  3. ओरेकल DATE और TIMESTAMP के बीच अंतर

  4. Oracle:क्या 10g oracle क्लाइंट 11g सर्वर के साथ काम करता है?

  5. अंतराल डेटा-प्रकार से सेकंड की कुल संख्या निकालना