加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 22秒是在mysql中插入500行的好时机吗?

发布时间:2020-12-13 22:10:06 所属栏目:PHP教程 来源:网络整理
导读:以下php脚本大约需要22秒才能执行.这是正常的吗?如果不是什么会导致它慢慢执行? $conn = mysql_connect('localhost','root','123');mysql_select_db('mydb',$conn);$time1 = time();for ($i=1;$i500;$i++) {mysql_query("Insert into accounts(id,username
以下php脚本大约需要22秒才能执行.这是正常的吗?如果不是什么会导致它慢慢执行?

$conn = mysql_connect('localhost','root','123');
mysql_select_db('mydb',$conn);
$time1 = time();
for ($i=1;$i<500;$i++) {
mysql_query("Insert into accounts(id,username,email,password) VALUES("$i","$i",NOW())");
}
print time() - $time1; // return ~22

编辑:表结构:

CREATE TABLE IF NOT EXISTS `accounts` (
  `id` int(11) NOT NULL AUTO_INCREMENT,`username` varchar(20) NOT NULL,`email` varchar(200) NOT NULL,`password` varchar(20) NOT NULL,`status` varchar(10) DEFAULT 'pending',`email_newsletter_status` varchar(3) DEFAULT 'out',`email_type` varchar(4) DEFAULT 'text',`email_favorite_artists_status` varchar(3) DEFAULT 'out',`created_date` datetime DEFAULT NULL,PRIMARY KEY (`id`),UNIQUE KEY `username` (`username`),UNIQUE KEY `email` (`email`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=7500 ;

此代码仅用于测试插入速度.使用Zend框架(Zend_Db的插入方法)我得到了类似的结果,所以我认为它与mysql有关而不是php代码

Edit2:我知道有更好的方法来执行这个查询,但我想知道为什么这个问题太慢了.

解决方法

22秒是很长的一段时间.我的猜测是每次插入后,需要更新INDEX.

尝试将此作为交易.

mysql_query("START TRANSACTION");
for ($i=1;$i<500;$i++) {
    mysql_query("Insert into accounts(id,NOW())");
}
mysql_query("COMMIT");

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读