4

我想知道是否有可能在 mysql 存储函数或存储过程中将 mysql 查询组合为一个字符串变量,您可以稍后执行?我有一个get_district_part ((district_id INT,county_id INT,city_id INT,zip_id INT)) RETURNS INT引用该表的存储函数:

CREATE TABLE IF NOT EXISTS `modx`.covereage_district_part(
    id      INT     NOT NULL    AUTO_INCREMENT  PRIMARY KEY,
    districtID  INT     NOT NULL,
    countyID    INT,
    cityID      INT,
    zipID       INT,
    FOREIGN KEY (districtID) REFERENCES `modx`.coverage_district (id),
    FOREIGN KEY (countyID) REFERENCES `modx`.coverage_county (id),
    FOREIGN KEY (cityID) REFERENCES `modx`.coverage_city (id),
    FOREIGN KEY (zipID) REFERENCES `modx`.coverage_zip (id)
);

get_distrct_part旨在返回行数学的 id以及,和.district_id的某种组合。问题是我想返回与 id 的确切组合匹配的行的 id,而不是包含任何这些想法的行的 id。为此,我想对我的查询语句进行分段,以便它特定于提供的 id 构建。如果可以的话,我试图不必匹配空值。county_idcity_idzip_id

我意识到这可以用 PHP 轻松完成,但如果我不能出于其他原因,我希望将其作为 mysql 存储过程执行,那么所有其他函数都是存储过程。

4

1 回答 1

7

PREPARE是的,您可以EXECUTE在存储过程中将字符串作为动态 SQL。

delimiter //
CREATE PROCEDURE get_district_part (district_id INT, county_id INT, city_id INT, zip_id INT)
BEGIN
  SET @query = 'SELECT id FROM covereage_district_part WHERE 1=1';

  IF (district_id IS NOT NULL) THEN
    SET @query = CONCAT(@query, ' AND districtID=', district_id);
  END IF;

  IF (county_id IS NOT NULL) THEN
    SET @query = CONCAT(@query, ' AND countyID=', county_id);
  END IF;

  IF (city_id IS NOT NULL) THEN
    SET @query = CONCAT(@query, ' AND cityID=', city_id);
  END IF;

  IF (zip_id IS NOT NULL) THEN
    SET @query = CONCAT(@query, ' AND zipID=', zip_id);
  END IF;

  PREPARE stmt1 FROM @query;

  EXECUTE stmt1;
END //
delimiter ;

call get_district_part(1,1,1,1);
call get_district_part(1,1,null,null);

注意:但是,您不能在存储函数中执行动态 SQL。RETURNS您的问题提到使用将是存储函数的子句声明您的例程。

于 2010-08-18T21:27:15.613 回答