在mysql中传递变量时出错
我花了数小时(搜索和尝试)在每一个简单的Mysql查询中。我试图将一个变量从一个select语句传递到下一个语句。但我被扔到了一个空的行列在mysql中传递变量时出错,mysql,database,Mysql,Database,我花了数小时(搜索和尝试)在每一个简单的Mysql查询中。我试图将一个变量从一个select语句传递到下一个语句。但我被扔到了一个空的行列 SET @id :='SELECT MAX(sId) from surveys'; SELECT typeId as type from surveys WHERE sId=@id; PREPARE stmt from @id; execute stmt; 我试着执行从调查中选择MAX(sId),结果符合要求。但是,@id似乎不接受这些值。解决这个问题有任
SET @id :='SELECT MAX(sId) from surveys';
SELECT typeId as type from surveys WHERE sId=@id;
PREPARE stmt from @id;
execute stmt;
我试着执行从调查中选择MAX(sId)
,结果符合要求。但是,@id
似乎不接受这些值。解决这个问题有任何错误或其他建议吗?试试这个:
SET @s = 'SELECT typeId as type from surveys WHERE sId=?';
PREPARE stmt from @s;
SET @id = (SELECT MAX(sId) from surveys);
EXECUTE stmt USING @id;
DEALLOCATE PREPARE stmt;
试试这个:
SET @s = 'SELECT typeId as type from surveys WHERE sId=?';
PREPARE stmt from @s;
SET @id = (SELECT MAX(sId) from surveys);
EXECUTE stmt USING @id;
DEALLOCATE PREPARE stmt;
这仍然会导致结果集为空。我直接在phymyadmin SQL字段中工作,并使用Delimiter。它对输出有什么影响吗?这仍然会导致结果集为空。我直接在phymyadmin SQL字段中工作,并使用Delimiter。这对输出有什么影响吗?