Link to home
Start Free TrialLog in
Avatar of erenpasa
erenpasa

asked on

Mysql Stored Procedure Dynamic Paramter For Cursor

Hi to all,
I want to pass a db name ChangeCreationDate function to alter all tables of db which passed via parameters.
But i take an error Unknown database 'dbName'.. I can't use database name dynamically. How can i do this?

Thanks
DELIMITER $$
 
DROP PROCEDURE IF EXISTS `ChangeCreationDate`$$
 
CREATE  PROCEDURE `ChangeCreationDate`(dbName VARCHAR(50))
BEGIN
  DECLARE done INT DEFAULT 0;
  DECLARE tableName TINYTEXT;
  DECLARE cur1 CURSOR FOR SHOW TABLES FROM dbName; //i need at here db name passes via parameter.
  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
  OPEN cur1;
  REPEAT
    FETCH cur1 INTO tableName;
    SELECT tableName;
    IF NOT done THEN
		IF SUBSTRING(tableName,1,3)='fd_' THEN
			IF v5_versioning.ColumnIsExists(dbName,tableName,'creation_date') THEN
				SET @ssql=CONCAT('ALTER TABLE ',dbName,'.',tableName,' CHANGE creation_date created_date TIMESTAMP');
				SELECT @ssql;
				/*
				PREPARE stmt FROM @ssql;
				EXECUTE stmt;
				*/
			END IF;
		END IF;
    END IF;
  UNTIL done END REPEAT;
  CLOSE cur1;
END$$
 
DELIMITER ;

Open in new window

ASKER CERTIFIED SOLUTION
Avatar of erenpasa
erenpasa

Link to home
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
Start Free Trial