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

क्या कोई SQL क्वेरी है जो हमेशा शून्य परिणाम देगी?

DBMS के आधार पर, निम्न में से एक या अधिक कार्य करेगा:

  • SELECT NULL LIMIT 0 (पोस्टग्रेएसक्यूएल और माईएसक्यूएल सिंटैक्स) / SELECT TOP 0 1 (एमएस एसक्यूएल सर्वर सिंटैक्स)
  • SELECT NULL WHERE FALSE (बूलियन प्रकार के साथ DBMS, जैसे PostgreSQL) SELECT NULL WHERE 1=0 (अधिकांश DBMSes)

Oracle के लिए, इन्हें SELECT NULL FROM DUAL . के रूप में होना चाहिए , मुझे विश्वास है, क्योंकि आपके पास SELECT नहीं हो सकता है बिना FROM . के किसी प्रकार का खंड; सुनिश्चित नहीं हैं कि LIMIT . के कौन से संस्करण हैं / TOP और WHERE यह स्वीकार करेगा।

एक अधिक विस्तृत विकल्प यह है कि एक (अस्थायी) तालिका बनाई जाए और उसमें कोई पंक्तियाँ न डालें, जो आपको किसी भी संख्या में कॉलम दे सकती हैं, जिनमें कोई मान न होने पर भी प्रकार जुड़े होंगे:

-- PostgreSQL
CREATE TEMP TABLE dummy ( a Int, b VarChar(42) );
SELECT * FROM dummy;

-- MS SQL Server
CREATE TABLE #DUMMY ( a Int, b VarChar(42) );
SELECT * FROM #DUMMY;

PostgreSQL में, आप बिना कॉलम वाली तालिका भी बना सकते हैं, जिससे आप शून्य पंक्तियों और शून्य स्तंभों के साथ परिणाम सेट कर सकते हैं। :

CREATE TEMP TABLE empty ();
SELECT * FROM empty;

एक और संभावना यह है कि यदि डीबीएमएस में सेट-रिटर्निंग फ़ंक्शन हैं, तो वे एक खाली सेट वापस करने में सक्षम हो सकते हैं। उदाहरण के लिए, फिर से PostgreSQL में जैसा कि मैं सबसे अच्छी तरह जानता हूं, आप generate_series() :

SELECT * FROM generate_series(0,-1);


  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. पायथन और MySQL प्रिंट परिणाम

  3. MySQL में एकाधिक पंक्तियों को एक कॉलम में कैसे संयोजित करें

  4. MySQL - करीबी मिलान ढूँढना

  5. Symfony2 इकाई संबंध बनाना और बनाए रखना