mysql添加多数据语句_⽤⼀条mysql语句插⼊多条数据
假如有⼀个数据表A:
id name title addtime
如果需要插⼊n条数据 :
$time= time();
$data = array(
array(
'name'=>'name1','title'=>'title1','addtime'=>$time;
),
array(
'name'=>'name2','title'=>'title2','addtime'=>$time;
)
,
array(
'name'=>'name3','title'=>'title3','addtime'=>$time;
),
...
array(
'name'=>'nameN','title'=>'titleN','addtime'=>$time;
),
);
之前我的想法会是,通过数据构造多条插⼊语句,循环调⽤ 。如:
$sql1 = "INSERT INTO `A`(`name`,`title`,`addtime`)VALUES ('name1','title1','".$time."')";
$sql2 = "INSERT INTO `A`(`name`,`title`,`addtime`)VALUES ('name2','title2','".$time."')";
......
$sqlN = "INSERT INTO `A`(`name`,`title`,`addtime`)VALUES ('nameN','titleN','".$time."')";
之后发现了sql的insert语句可以⼀次插⼊多条:数据库优化sql语句
$sql = "INSERT INTO `A`(`name`,`title`,`addtime`)VALUES ('name1','title1','".$time."'),";
$sql .= "('name2','title2','".$time."'),";
$sql .= "('name3','title3','".$time."'),";
.....
$sql .= "('nameN','titleN','".$time."')";
通过","号将多个数据分隔开来,就可以能过⼀条sql操作来解决多个数据的插⼊,之前试验时,在插⼊数据条数为30的情况下,⼀次插⼊与多次插⼊同样数据的速度相⽐,⼀次插⼊快了近9倍。同时,因为插⼊操作只有⼀次,所以也类似事务操作,插⼊失败则全失败,插⼊成功则全成功,使数据的管理更
加⽅便。所以,如果有多条数据需要插⼊同⼀个表的,尽量⽤这种⽅式。
以前插⼊多条数据库记录时,常这么写:
$b = 14;
for($a=0;$a<100;$a++){
$sql = " INSERT INTO `roles` (`uid`,`rid`) VALUES (".$a.",".$b.")";
mysql_query($sql);
}
但这种写法效率低下,需要多次执⾏sql语句。如果你⽤过phpmyadmin导⼊数据,其实你会发现,上⾯的语句其实可以这么写
INSERT INTO `roles` (`uid`,`rid`) VALUES
(534,14),(535,14),(536,14),(537,14),(539,14)
所以原来的代码可以这么改写
$b = 14;
for($a=0;$a<100;$a++){
if($a==0)
$sql = "INSERT INTO `roles` (`uid`,`rid`) VALUES (".$a.",".$b.")";
else
$sql. = ",(".$a.",".$b.")";
}
mysql_query($sql);
您可能感兴趣的⽂章:C++操作MySQL⼤量数据插⼊效率低下的解决⽅法Java使⽤JDBC向MySQL数据库批次插⼊10W条数据(测试效率)MySql批量插⼊优化Sql执⾏效率实例详解mysql中迅速插⼊百万条测试数据的⽅法MYSQL批量插⼊数据的实现代码mysql数据库插⼊速度和读取速度的调整记录MySql避免重复插⼊记录的⼏种⽅法Mysql中⼏种插⼊效率的实例对⽐
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论