当前位置: 首页 > 图文教程 > 网络编程 > PHP > 多个字段,大量记录的插入操作技巧(PHP)

PHP
精通PHP的十大要点
从SQL server中将数据库导入Mysql数据库
使用PHP程序直接调用文本文件的内容实例
增加PHP的Session存储和处理能力
关于PHP操作文件的一些FAQ总结
PHP程序开发的原则汇总
PHP开发者必不可少的五个发展要素
PHP数组读取的循环操作
PHP识别24位BMP的验证码
PHP开发人员应熟悉的五个概念
PHP网站开发需要掌握的10个技巧
三种解决PHP乱码问题的办法
PHP下载文件名乱码问题详解
PHP安全之Register Globals
PHP构建语义Web CRUD操作
40条技巧优化php代码
xml+php动态载入与分页
PHP安全之错误报告
网页中PHP脚本中include文件报错解决方法
php分页类 只用传入总页数

多个字段,大量记录的插入操作技巧(PHP)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 105 ::
收藏到网摘: n/a

以下为引用的内容:
$query = "select s_no from students where ......";
  
  $re = mysql_query($query,$lnk);
  
  while

 ($form = mysql_fetch_object($re))
  
  {
  
  //获得学号的最后两位.
  
  $student_no = $form->s_no % 100;
  
  ?>
  
  <tr>
  
  <td height="20">
  
  <?=$form->s_no;?>
  
  </td>
  
  <!-
  
  动态生成text域的name属性,注意!不要写id属性,以免重复!
  
  ->
  
  <td><input name="a<?=$student_no;?>" type="text"
  size="10" maxlength="10"></td>
  
  <td><input name="b<?=$student_no;?>" type="text"
  size="10" maxlength="10"></td>
  
  </tr>
  
  <?
  
  }
  
  ?>
  
  <tr>
  
  <td height="20" colspan="3"><div align="center">
  
  
  <input type="submit" name="Submit" value="Submit">
  
  </div></td>
  
  </tr>
  
  </table>
  
  </form>
  
  </body>
  
  </html>

结果如下,共有这么些SQL语句被执行:
  insert into score (s_no,grade,class,class2,score) values ('990001','99','6','a','90')
  insert into score (s_no,grade,class,class2,score) values ('990002','99','6','a','86')
  insert into score (s_no,grade,class,class2,score) values ('990003','99','6','a','84')
  insert into score (s_no,grade,class,class2,score) values ('990005','99','6','b','75')
  insert into score (s_no,grade,class,class2,score) values ('990006','99','6','b','80')
  insert into score (s_no,grade,class,class2,score) values ('990007','99','6','b','79')
  一个班级需要40多次循环,mysql_query()函数执行40余次,在网络环境较好的情况下,耗时1秒左右(mysql就是快)当然,可以生成一条超长的SQL语句,执行一次query.至于哪个效率更高,大家自己试试看吧.这个方法的优点就是可以不必一次次点击"递交",不足之处在于,一次必须把数据全部输入!(有点矛盾?)是的!如果再次使用这个功能,而又输入重复的数据会怎样?解决办法是有的,就是每次循环时执行query前,判断该记录是否存在.这似乎又得执行一条额外的query.就是说,要确保数据正确,而一个班有n个人的话,总共需要N*2次query.
  还有一个办法是在生成表单的时候加以限制,这样可以分散系统负荷,明显要好过前一个方案.