视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
多个字段,大量记录的插入操作技巧(PHP)_MySQL
2020-11-09 17:20:38 责编:小采
文档


在使用php+mysql开发的时候,插入/删除数据是免不了的,我想大家早已习惯了诸如bbs发表,留言簿的一条,一条的数据输入的模式.
但是在很多工程里,逐条输入数据是不被允许的.
比如,输入学生的考试成绩,逐条输入需要点击"提交"40多次,这很大程度消磨了班主任的耐心和时间,如何"一口气"输入完一个班级的数据,是校园管理系统的一个要点(当然,其他场合也经常有这种要求)
下面的文章仅仅是我的工作经验,供学习PHP的同道们参考.(高手大概会一笑了之吧)
主要思路有二:1.动态生成表单和域的属性
2.用变量表示变量

首先看看数据结构:
create table score
(
score_id int unsigned primary key auto_increment,
s_no int unsigned not null,
grade tinyint not null,
class tinyint not null,
class2 tinyint ,
subject char(6) not null,
score tinyint default '0'
)type=MYISAM;

create table students
(
imitate int unsigned primary key,
s_no int unsigned ,
s_name char(10) not null,
......
)type=MYISAM;
其中s_no是学号,是整个程序的关键.由于这个学校语数外是分8个等级班的,所以,成绩表中多一个class2字段.
目的是在一个表单中输入全班40多人的"分类班,成绩"数据,一次性提交.
由于输入牵涉多个字段,而且需要插入的记录不止一条,给编程提高了难度.这里牵涉了2个字段,但是我们举一反三后可以解决任何多个字段的问题.(当然,表单是需要动态生成的.)

废话不多说了,看看源代码吧:
(因为这个站点没有把html标签给过滤掉,请大家把下面代码copy到dreamweaver的代码视图里再看.)

//连接数据库

include("const.php");

include("link.php");

//如果没有表单提交,执行下面操作

if(!empty($HTTP_POST_VARS)) {

//获得POST变量

$grade = $_POST["grade"];

$tclass = $_POST["tclass"];

//由于学号最后两位不会超过60,我们一个一个接收

for($i = 1;$i < 60;$i++) {

//第一条记录的分类班和成绩的"变量名"(注意还不是数值)

$fenlei = "a".$i;

$score = "b".$i;

//因为学号可能有间隔,先判断值是否存在

if(!empty($_POST["$fenlei"]) && !empty($_POST["$score"]))
{

//如果register_globals = on,则下面直接使用$$fenlei和$$score.

//我们假设register_globals = on,如果你的设置不是,那么请再定义两个变量接收它们的值.

//重新生成完整的学号.

$s_no = $grade*10000+$class*100+$i;

//生成query语句,用到了"变量的变量".当然,如果register_globals = off,则又有不同.

$query = "insert into score (s_no,grade,class,class2,score) values ('$s_no','$grade','$tclass','".$$fenlei."','".$$score."')";

//显示,看看语句是否正确.

echo $query."
";

//执行语句,我没有写出来.

}

}

}

?>

TEST


结果如下,共有这么些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.
还有一个办法是在生成表单的时候加以,这样可以分散系统负荷,明显要好过前一个方案.

不知道还有没有更好的办法使效率和稳定兼得,靠大家指教了.

下载本文
显示全文
专题