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

विशिष्ट समय सीमा के लिए डेटा प्राप्त करें

मुझे लगता है कि समस्या आपके WHERE . में मूल्यांकन के क्रम में है खंड। मैं हमेशा OR . के आस-पास कोष्ठक का उपयोग करें एसक्यूएल में ऑपरेटरों। निम्नलिखित MySQL 5.6 पर काम करता है।

SELECT * 
FROM tb_test
WHERE  datecreate between '2018-09-24 19:00:00' and '2018-09-26 07:00:00'
AND (hour(DateCreate) >= 19 or hour(DateCreate) < 7);

संदर्भ के लिए, मैंने इस परीक्षण स्कीमा का उपयोग किया:

CREATE table tb_test
(datecreate datetime);

CREATE OR REPLACE VIEW generator_16
AS SELECT 0 n UNION ALL SELECT 1  UNION ALL SELECT 2  UNION ALL 
 SELECT 3   UNION ALL SELECT 4  UNION ALL SELECT 5  UNION ALL
 SELECT 6   UNION ALL SELECT 7  UNION ALL SELECT 8  UNION ALL
 SELECT 9   UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL
 SELECT 12  UNION ALL SELECT 13 UNION ALL SELECT 14 UNION ALL 
 SELECT 15;

CREATE OR REPLACE VIEW generator_256
AS SELECT ( ( hi.n << 4 ) | lo.n ) AS n
 FROM generator_16 lo, generator_16 hi;

INSERT INTO tb_test
SELECT date_add("2018-09-24",interval n hour)
FROM generator_256;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. बहुभाषी के लिए url मान्य करें - जापानी langauga

  2. यदि पंक्ति मौजूद है तो अपडेट करें, अन्यथा किसी अन्य तालिका में नई पंक्ति डालें

  3. समूह द्वारा दो डीबी क्वेरी करें और विवरण जानकारी प्रदर्शित करें

  4. मैं कैसे जांचूं कि कोई कॉलम खाली है या MySQL में शून्य है?

  5. PHP, MySQL, PDO लेनदेन - क्या कोड के अंदर कोड कमिट () पर ब्लॉक करने की कोशिश करता है?