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"); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |