MySQL select 在过程中的 if 语句中
MySQL select within if statement in procedure
我必须创建一个过程来插入带有外键的行。这个键是来自另一个满足条件的 table 的随机 ID,如果没有满足它的行,那么它将是来自 table.
中所有 ID 的随机 ID
例如,我想创建一个人,我想给他一辆车。我希望他的车是从特定颜色中随机选择的,但是如果没有那种颜色的车,那么就随机选择一辆。
这是我改编的当前代码:
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 命令不同步;你现在不能运行这个命令'
不知道是否可以那样做。
我使用定界符是因为我必须添加更多内容。
你可以这样做:
INSERT INTO persons(id_color)
SELECT car_id
FROM cars
ORDER BY (color = id_color) DESC, RAND()
LIMIT 1
第一个排序标准首先打印具有给定颜色的汽车(如果有的话)。第二个标准洗牌。
令我惊讶的是插入不涉及另一列,通常用于存储汽车分配给的人。
我必须创建一个过程来插入带有外键的行。这个键是来自另一个满足条件的 table 的随机 ID,如果没有满足它的行,那么它将是来自 table.
中所有 ID 的随机 ID例如,我想创建一个人,我想给他一辆车。我希望他的车是从特定颜色中随机选择的,但是如果没有那种颜色的车,那么就随机选择一辆。
这是我改编的当前代码:
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 命令不同步;你现在不能运行这个命令'
不知道是否可以那样做。
我使用定界符是因为我必须添加更多内容。
你可以这样做:
INSERT INTO persons(id_color)
SELECT car_id
FROM cars
ORDER BY (color = id_color) DESC, RAND()
LIMIT 1
第一个排序标准首先打印具有给定颜色的汽车(如果有的话)。第二个标准洗牌。
令我惊讶的是插入不涉及另一列,通常用于存储汽车分配给的人。