【发布时间】:2021-04-04 05:49:40
【问题描述】:
我必须创建一个使用外键插入行的过程。该键是另一个表中满足条件的随机id,如果没有满足它的行,则它将是表中所有id中的随机id。
例如,我想创建一个 Person 并且我想为他分配一辆汽车。我希望他的汽车是从特定颜色中随机选择的,但如果没有该颜色的汽车,则只需选择随机汽车。
这是我改编的当前代码:
DELIMITER //
DROP PROCEDURE IF EXISTS `test`;
CREATE PROCEDURE `test`( `id_color` INT )
BEGIN
# I have auto increment id
INSERT INTO persons(id_color)
VALUES ((
SELECT IF((SELECT COUNT(*) FROM cars WHERE color = id_color) > 0,
SELECT car_id FROM cars WHERE color = id_color ORDER BY RAND() LIMIT 1,
SELECT car_id FROM cars ORDER BY RAND() LIMIT 1)
));
END //
DELIMITER ;
我收到此错误:'2014 命令不同步;你现在不能运行这个命令'
不知道能不能这样。
我使用分隔符是因为我必须添加更多内容。
【问题讨论】:
标签: mysql sql random sql-order-by sql-insert