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

MySQL में सीमांकक

डिफ़ॉल्ट के अलावा अन्य सीमांकक ; आमतौर पर फ़ंक्शंस, संग्रहीत प्रक्रियाओं और ट्रिगर्स को परिभाषित करते समय उपयोग किया जाता है जिसमें आपको कई कथनों को परिभाषित करना होगा। आप $$ . जैसे भिन्न सीमांकक को परिभाषित करते हैं जिसका उपयोग पूरी प्रक्रिया के अंत को परिभाषित करने के लिए किया जाता है, लेकिन इसके अंदर, प्रत्येक कथन को ; द्वारा समाप्त किया जाता है . इस तरह, जब कोड mysql . में चलाया जाता है क्लाइंट, क्लाइंट बता सकता है कि पूरी प्रक्रिया कहां समाप्त होती है और इसे एक इकाई के रूप में निष्पादित करने के बजाय अलग-अलग बयानों को अंदर निष्पादित कर सकता है।

ध्यान दें कि DELIMITER कीवर्ड कमांड लाइन का एक कार्य है mysql क्लाइंट (और कुछ अन्य क्लाइंट) केवल एक नियमित MySQL भाषा सुविधा नहीं है। यदि आप इसे प्रोग्रामिंग भाषा एपीआई के माध्यम से MySQL में पास करने का प्रयास करते हैं तो यह काम नहीं करेगा। कुछ अन्य क्लाइंट जैसे PHPMyAdmin के पास गैर-डिफ़ॉल्ट सीमांकक निर्दिष्ट करने के अन्य तरीके हैं।

उदाहरण:

DELIMITER $$
/* This is a complete statement, not part of the procedure, so use the custom delimiter $$ */
DROP PROCEDURE my_procedure$$

/* Now start the procedure code */
CREATE PROCEDURE my_procedure ()
BEGIN    
  /* Inside the procedure, individual statements terminate with ; */
  CREATE TABLE tablea (
     col1 INT,
     col2 INT
  );

  INSERT INTO tablea
    SELECT * FROM table1;

  CREATE TABLE tableb (
     col1 INT,
     col2 INT
  );
  INSERT INTO tableb
    SELECT * FROM table2;
  
/* whole procedure ends with the custom delimiter */
END$$

/* Finally, reset the delimiter to the default ; */
DELIMITER ;

DELIMITER का उपयोग करने का प्रयास कर रहा है एक क्लाइंट के साथ जो इसका समर्थन नहीं करता है, उसे सर्वर पर भेजा जाएगा, जो एक सिंटैक्स त्रुटि की रिपोर्ट करेगा। उदाहरण के लिए, PHP और MySQLi का उपयोग करना:

$mysqli = new mysqli('localhost', 'user', 'pass', 'test');
$result = $mysqli->query('DELIMITER $$');
echo $mysqli->error;

इसमें त्रुटियां:

<ब्लॉकक्वॉट>

आपको अपने SQL सिंटैक्स में कोई त्रुटि है; लाइन 1 पर 'DELIMITER $$' के पास उपयोग करने के लिए सही सिंटैक्स के लिए अपने MySQL सर्वर संस्करण से संबंधित मैनुअल की जाँच करें



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

  2. क्या MySQL के लिए कोई प्रोफाइलर समकक्ष है?

  3. GROUP_CONCAT सीमा के साथ

  4. दिनांक स्ट्रिंग को mysql डेटाटाइम फ़ील्ड में बदलें

  5. उच्च उपलब्धता के लिए Percona XtraDB क्लस्टर 8 को कैसे परिनियोजित करें