如何用insert into 跨数据库values插入多条数据

下次自动登录
现在的位置:
& 综合 & 正文
sqlite3-批量insert插入多条信息-提高效率的办法
这也是之前进行了十万级别的insert插入信息,因为数量太多,所以感觉一条一条执行简直慢的要死……经过查询,找到了对应的解决办法,极大的提升了插入多条消息的效率。
之所以慢,就是因为每一条指令都成了一个事务,从而极大的降低了执行效率,解决办法就是把所有的指令归结为一个事务一次执行即可。
下面就是类比
/*开始事务*/
/*万条记录开始*/
insert into [表名] values();
/*万条记录结束*/
/*执行事务*/
利用事务,可以将几十分钟的执行指令大幅缩减到几十秒。因为因为这个过程只写一次磁盘。
还有一个思路,就是使用sqlite内存表,将数据先写到内存表,然后再更新到磁盘表。
(以下部分代码来自:/node/41507)
$conn = new PDO('sqlite::memory:');
$conn-&exec("CREATE TABLE t1 (id1 interge,str1 varchar(30))");
$conn-&exec("begin transaction");
$sql = '';
for($i=0;$i&1000000;$i++) {
$sql = "INSERT INTO t1 VALUES ({$i}, '阿斯蒂芬是否');";
$conn-&exec($sql);
$conn-&exec("commit transaction");
//内存表刷到磁盘
$conn-&exec('ATTACH "D:\test.db" AS test1');
$conn-&exec("insert into test1.t1 SELECT * FROM t1");
$conn-&exec('DETACH test1');
原始博主说这个过程和使用事务的时间差不多。我未测试。
用一个事务的办法就可以提高效率的了,暂时不深入研究了。
&&&&推荐文章:
【上篇】【下篇】用一条mysql语句插入多条数据
投稿:hebedich
字体:[ ] 类型:转载 时间:
这篇文章主要介绍了在mysql中使用一条sql语句插入多条数据,效率非常高,但是原理其实很简单,希望对大家有所帮助
&&&&&& 假如有一个数据表A:
id&name&title&addtime
&&&&&&& 如果需要插入n条数据 :
$time= time();
$data = array(
'name'=&'name1','title'=&'title1','addtime'=&$
'name'=&'name2','title'=&'title2','addtime'=&$
'name'=&'name3','title'=&'title3','addtime'=&$
'name'=&'nameN','title'=&'titleN','addtime'=&$
&& 之前我的想法会是,通过数据构造多条插入语句,循环调用 。如:&&&&&
$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 = "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倍。同时,因为插入操作只有一次,所以也类似事务操作,插入失败则全失败,插入成功则全成功,使数据的管理更加方便。所以,如果有多条数据需要插入同一个表的,尽量用这种方式。
以前插入多条数据库记录时,常这么写:
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)
所以原来的代码可以这么改写
for($a=0;$a&100;$a++){
$sql = "INSERT INTO `roles` (`uid`,`rid`) VALUES (".$a.",".$b.")";
$sql. = ",(".$a.",".$b.")";
mysql_query($sql);
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具INSERT INTO userinfo(username, departname, created) values(?,?,?) 后面的几个问号是什么意思? - 知乎4被浏览2784分享邀请回答1添加评论分享收藏感谢收起

我要回帖

更多关于 insert into values多 的文章

 

随机推荐