我有点小麻烦。我需要在我们的网站上授予一个项目给用户,但我不想手动填写一个接一个的数字。有没有一种方法可以在不创建多行的情况下将UID 9 to 5430的SQL查询设置为INSERT INTO?这是我的例子。
INSERT INTO `item_owned` (`id`, `uid`, `iid`, `kind`, `time_owned`, `notes`) VALUES (NULL, 'x', '3626', '1', '1592596732', 'NotBanned')我试着让"x“是一个数字,但是让MYSQL生成9到5430之间的多个数字,而不必一次生成多个数字/代码。所以就像这样:
INSERT INTO `item_owned` (`id`, `uid`, `iid`, `kind`, `time_owned`, `notes`) VALUES (NULL, '9 - 5430', '3626', '1', '1592596732', 'NotBanned')9 - 5430是问题所在。我想把这个项目奖励给数字在9 and 5430之间的每一个人。
感谢你的帮助-谢谢。
发布于 2020-07-13 11:10:12
您可以使用mysql中的存储过程来完成此操作;在存储过程中,您可以使用循环来插入多个条目。我在下面提供了一个例子。
过程可以像如下所示的代码一样实现:
delimiter $$
create procedure fill_rows(in start_index int,in termination_point int)
begin
while start_index <= termination_point do
INSERT INTO `item_owned` (`id`, `uid`, `iid`, `kind`, `time_owned`, `notes`) VALUES (NULL, start_index, '3626', '1', '1592596732', 'NotBanned');
set start_index := start_index + 1;
end while;
end $$
delimiter ;现在,只要你想插入uid,假设从x到y的范围是x到y,假设x= 10,y= 1000,那么你可以简单地使用这个一次性的过程调用来插入这个记录,如下所示:
call fill_row(10, 1000);此调用将插入990个具有uid值10、11、12 ...1000的新行。希望这能对你有所帮助!
https://stackoverflow.com/questions/62857187
复制相似问题