2011-04-08 12 views
6

में एक चर में ouput मिल मैं अपने एसक्यूएल संग्रहित प्रक्रिया में एक गतिशील क्वेरी उत्पन्न करते हैं। मैं इस क्वेरी का परिणाम आउट पैरामीटर में प्राप्त करना चाहता हूं। यह कैसे करना है ?मेरे एसक्यूएल गतिशील क्वेरी निष्पादित और संग्रहीत प्रक्रिया

CREATE PROCEDURE 'searchInvoice' 
(
    OUT numOfRecords INT 
) 
BEGIN 
    DECLARE query1 TEXT; 
    DECLARE query2 TEXT; 

SET query1 = 'SELECT COUNT(*) bla bla bla.....'; 
// Query1 to select the count of matching tuples.. 

SET query2 = 'SELECT * from bla bla bla....'; 
// Query2 to select original records... 

// later part of this both queries generate dynamically according to some IN parameters.. 

// now I wanna assign the output of the query1 into numOfRecords 
// and I wanna execute the query2 as well.. like this 

    SET @Sql = query2;   
    PREPARE STMT FROM @Sql; 
    EXECUTE STMT; 
    DEALLOCATE PREPARE STMT; 

// output of the query2 can be read in PHP 

END 

कैसे बाहर पैरामीटर (numOfRecords) में QUERY1 के उत्पादन प्राप्त करने के लिए ??

उत्तर

21

इस उदाहरण पर एक नज़र डालें -

CREATE TABLE table1(
    column1 VARCHAR(255) DEFAULT NULL, 
    column2 VARCHAR(255) DEFAULT NULL, 
    column3 VARCHAR(255) DEFAULT NULL 
); 

INSERT INTO table1 VALUES 
    ('1', 'value1', 'value2'), 
    ('2', 'value3', 'value4'); 

DELIMITER $$ 
CREATE PROCEDURE procedure1(IN Param1 VARCHAR(255), OUT Param2 VARCHAR(255), OUT Param3 VARCHAR(255)) 
BEGIN 
    SET @c2 = ''; 
    SET @c3 = ''; 
    SET @query = 'SELECT column2, column3 INTO @c2, @c3 FROM table1 WHERE column1 = ?'; 
    PREPARE stmt FROM @query; 
    SET @c1 = Param1; 
    EXECUTE stmt USING @c1; 
    DEALLOCATE PREPARE stmt; 
    SET Param2 = @c2; 
    SET Param3 = @c3; 
END$$ 
DELIMITER ; 

-- Call procedure and use variables 
SET @Param1 = 2; 
SET @Param2 = ''; 
SET @Param3 = ''; 
CALL procedure1(@Param1, @Param2, @Param3); 
SELECT @Param2, @Param3; 
+---------+---------+ 
| @Param2 | @Param3 | 
+---------+---------+ 
| value3 | value4 | 
+---------+---------+ 
+2

धन्यवाद Devart .... यह जवाब है ... आपके प्रयास ... – Sency

+0

धन्यवाद @Devart लिए फिर से धन्यवाद। अच्छा काम – Sami

+0

@ डिवार्ट करें यदि एकाधिक रिकॉर्ड प्राप्त हो रहे हैं, तो temp तालिका में कैसे स्टोर करें? –

2
select count(*) into @numOfRecords from .... 

आप संग्रहीत प्रक्रिया

मुझे आशा है कि मैं अपने प्रश्न समझ लिया है के भीतर चर घोषित करते हैं।

संबंधित मुद्दे