mysql 插入数据报错 Truncated incorrect DOUBLE value

插入语句为:

delimiter //
create procedure create_test_data()
begin
    declare i int default 1;
    set i = 1;
    while i <= 10000000 do
        insert into person (name, age, childs) VALUES
        ('张三' +  i, rand() * 100, rand() * 10);
        end while;
end //
delimiter ;

报错:

Truncated incorrect DOUBLE value:张三

我觉得是zhangsan + i执行出了问题,类似java代码不同类型的数据相加,所以修改为:

delimiter //
create procedure create_test_data()
begin
    declare i int default 1;
    set i = 1;
    while i <= 10000000 do
        insert into person (name, age, childs) VALUES
        (concat('张三', i), rand() * 100, rand() * 10);
        end while;
end //
delimiter ;

这样就可以了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章