首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在MySQL中轻松插入多行?

在MySQL中轻松插入多行?
EN

Stack Overflow用户
提问于 2020-07-12 12:47:05
回答 1查看 147关注 0票数 1

我有点小麻烦。我需要在我们的网站上授予一个项目给用户,但我不想手动填写一个接一个的数字。有没有一种方法可以在不创建多行的情况下将UID 9 to 5430的SQL查询设置为INSERT INTO?这是我的例子。

代码语言:javascript
复制
INSERT INTO `item_owned` (`id`, `uid`, `iid`, `kind`, `time_owned`, `notes`) VALUES (NULL, 'x', '3626', '1', '1592596732', 'NotBanned')

我试着让"x“是一个数字,但是让MYSQL生成9到5430之间的多个数字,而不必一次生成多个数字/代码。所以就像这样:

代码语言:javascript
复制
INSERT INTO `item_owned` (`id`, `uid`, `iid`, `kind`, `time_owned`, `notes`) VALUES (NULL, '9 - 5430', '3626', '1', '1592596732', 'NotBanned')

9 - 5430是问题所在。我想把这个项目奖励给数字在9 and 5430之间的每一个人。

感谢你的帮助-谢谢。

EN

回答 1

Stack Overflow用户

发布于 2020-07-13 11:10:12

您可以使用mysql中的存储过程来完成此操作;在存储过程中,您可以使用循环来插入多个条目。我在下面提供了一个例子。

过程可以像如下所示的代码一样实现:

代码语言:javascript
复制
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,那么你可以简单地使用这个一次性的过程调用来插入这个记录,如下所示:

代码语言:javascript
复制
call fill_row(10, 1000);

此调用将插入990个具有uid值10、11、12 ...1000的新行。希望这能对你有所帮助!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62857187

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档