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

PHP
AJAX在PHP中的简单使用
vim下高亮显示php代码
用 PHP 使 Web 数据分析进入更高境界
用Apache与MySQL整合实现基本身份认证
通用PHP动态生成静态HTML网页的代码
自己轻松修复Discuz!数据库技巧
PHP在Web开发领域的优势在哪?
php4和php5单态模式(Singleton Pattern)写法
使用Xdebug优化你的php程序
PHP学习入门的一些基础知识
关于正则表达式学习
浅谈PHP开发团队的管理之道
传奇的诞生,PHP三位创始人简介
利用PHP制作简单的内容采集器
PHP精确到每一秒钟的在线人数显示代码
一些PHP学习过程中的心得和经验
WINDOWS服务器安装多套PHP的另类解决方案
让你的PHP引擎全速运转的三个简单绝招
大型系统上PHP令人不爽的九大原因
php的计数器程序

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 74 ::
收藏到网摘: 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.
  还有一个办法是在生成表单的时候加以限制,这样可以分散系统负荷,明显要好过前一个方案.