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

किसी अन्य संग्रहीत कार्यविधि में mySQL संग्रहीत कार्यविधि परिणाम प्राप्त करना

ऐसा प्रतीत होता है (इस समुदाय के अनुसार और क्योंकि मुझे अन्य संग्रहित प्रक्रियाओं के परिणाम सेट का उपयोग करके नई चुनिंदा तालिकाओं में तालिकाओं के रूप में संग्रहीत प्रक्रियाओं का कोई उदाहरण नहीं मिला) कि MySQL या तो इसका समर्थन नहीं करता है या यह कि मैं जो करना चाहता हूं वह हास्यास्पद रूप से कठिन है करने की उम्मीद है।

इसलिए संग्रहीत कार्यविधियों को कॉल करने के बजाय मैंने इस अंतिम प्रक्रिया में प्रश्नों की प्रतिलिपि बनाई।

    DELIMITER $$

    CREATE DEFINER=`root`@`localhost` PROCEDURE `get_team_stats_change`(
        IN team_id INT
    )
    BEGIN
    SELECT SUM(start_weight) AS start_weight, 
        SUM(start_body_fat) AS start_body_fat, 
        SUM(current_weight) AS current_weight,
        SUM(current_body_fat) AS current_body_fat,
        SUM(weight_change) AS weight_change, 
        SUM(body_fat_change) AS body_fat_change FROM (
    SELECT ls.person_id, 
        fs.weight AS start_weight, fs.body_fat AS start_body_fat, 
        ls.weight AS current_weight, ls.body_fat AS current_body_fat,
        fs.weight - ls.weight AS weight_change, fs.body_fat - ls.body_fat AS body_fat_change
    FROM
    (SELECT ttd.person_id, bs.weight, bs.body_fat, bs.test_date
    FROM body_stats AS bs
    JOIN
        ((SELECT pbs.person_id,  min(bs.test_date)  AS first_test, max(bs.test_date) AS last_test   
        FROM body_stats AS bs,
            person_body_stats AS pbs,
            team_member AS tm,
            team AS t
        WHERE t.team_id = team_id
        AND tm.team_id = t.team_id
        AND tm.person_id = pbs.person_id
        AND pbs.body_stats_id = bs.body_stats_id
        AND tm.start_date  bs.test_date
        AND bs.test_date >= t.starting_date
        GROUP BY person_id) AS ttd,
        person_body_stats AS pbs)
    ON bs.test_date = ttd.first_test 
        AND pbs.person_id = ttd.person_id 
        AND pbs.body_stats_id = bs.body_stats_id) AS fs,

    (SELECT ttd.person_id, bs.weight, bs.body_fat, bs.test_date
    FROM body_stats AS bs
    JOIN
        ((SELECT pbs.person_id,  min(bs.test_date)  AS first_test, max(bs.test_date) AS last_test   
        FROM body_stats AS bs,
            person_body_stats AS pbs,
            team_member AS tm,
            team AS t
        WHERE t.team_id = team_id
        AND tm.team_id = t.team_id
        AND tm.person_id = pbs.person_id
        AND pbs.body_stats_id = bs.body_stats_id
        AND tm.start_date  bs.test_date
        AND bs.test_date >= t.starting_date
        GROUP BY person_id) AS ttd,
        person_body_stats AS pbs)
    ON bs.test_date = ttd.last_test 
        AND pbs.person_id = ttd.person_id 
        AND pbs.body_stats_id = bs.body_stats_id) AS ls
        WHERE ls.person_id = fs.person_id
       ) AS delta;
    END



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. एकाधिक चित्र अपलोड करें और उनके पथ को डेटाबेस में संग्रहीत करें

  2. लार्वा डीबी के साथ पेजिनेशन का उपयोग कैसे करें ::क्वेरी का चयन करें

  3. मैं MySQL द्वारा उपयोग किए जाने वाले डिफ़ॉल्ट स्टोरेज इंजन को कैसे सेट कर सकता हूं?

  4. Laravel Eloquent में कुछ फ़ील्ड्स का चयन कैसे करें?

  5. Sql क्वेरी केवल पहली पंक्ति लौटाती है