我做的是一个毕业设计选题系统,现在在熟悉代码。我知道哪个功能是通过哪段代码实现的,但是代码的具体含义我很模糊。望高手帮我在旁边注释在后边~~
由于我的这个项目是旧的基础上修改添加的部分功能,所以有时必须添加
extract($_POST);或者
extract($_REQUEST);才能运行一些功能,这是什么意思?
还有就是,我每一段执行数据库的代码后边都要跟这么几句
$query="select * from $student_table where xuehao='$xuehao'"; mysql_query("set names 'GB2312'"); $result=mysql_query($query); $row=mysql_fetch_array($result);
还有这是修改课题的一段,我就不知道sn和ssn是干什么的。
$query="select number as sn,surplus as ssn from $keti_table where id='$id'"; mysql_query("set names 'gb2312'"); $result=mysql_query($query); $row=mysql_fetch_array($result); if($number1<$row['sn']) { if($number1<($row['sn']-$row['ssn'])) { echo"<p align=\"center\"><font color=\"#FF0000\"><b><big>人数不能少于现已选题人数,人数列修改失败!</big></b></font>"; echo"<meta http-equiv=\"refresh\" content=\"2;url=alter_jiaoshi.php\">"; exit; } else { $query2=mysql_query("update $keti_table set number='$newnumber' where id='$id'"); $query3=mysql_query("update $keti_table set surplus=surplus-($row[sn]-$newnumber) where id='$id'"); mysql_query("set names 'gb2312'"); $result1=mysql_query($query3); } } else { $query4=mysql_query("update $keti_table set number='$newnumber' where id='$id'"); $query5=mysql_query("update $keti_table set surplus=surplus+($newnumber-$row[sn]) where id='$id'"); mysql_query("set names 'gb2312'"); $result2=mysql_query($query5); } if($result==true) { echo"<p align=\"center\"><font color=\"#FF0000\"><b><big>修改课题成功!</big></b></font>"; echo "<meta http-equiv=\"refresh\" content=\"1;url=jiaoshi_login.php\">"; exit; }
这是下载资料的一段代码
$file_name="相关资料.rar"; $file_dir="temp/./"; if(!file_exists($file_dir.$file_name)) { echo"<p align=\"center\"><font color=\"#FF0000\"><b><big>无法找到该文件</big></b></font></p>"; echo "<meta http-equiv=\"refresh\" content=\"1;url=download.php\">"; exit; } else{ $file=fopen($file_dir.$file_name,"r");//打开文件 Header("Content-type: application/octet-stream"); Header("Accept-Ranges:bytes"); Header("Accept-Length:".filesize($file_dir.$file_name)); Header("Content-Disposition: attachment; filename=".$file_name); readfile($file_dir.$file_name); }
尤其是最后这段关于“可选”与“不可选”表单的,不懂
$surplus=''; extract($_REQUEST); $n=0; if(empty($offset)) {$offset=0;} mysql_query("set names 'GB2312'"); $where = (isset($surplus) && strlen($surplus)>0) ? " where surplus='$surplus'" : ''; //不懂…… $query=mysql_query("select count(*) as sm from keti $where"); $row=mysql_fetch_array($query); $count=$row['sm']; //总记录数 $query=mysql_query("select * from keti $where order by id asc limit $offset,$list_num") or die ("fail");
回复讨论(解决方案)
extract 将数组导入变量表(关联键为变量名)
mysql_query("set names 'GB2312'"); 用于通知 mysql 以后的交互以 GB2312 字符集进行
通常在连接数据库以后执行一次就可以了
由
if($number1 echo"
人数不能少于现已选题人数,人数列修改失败!";
可知 sn 为备选人数, ssn 已选人数
无过滤条件查询
select count(*) as sm from keti
有过滤条件查询
select count(*) as sm from keti where surplus='$surplus'
extract 将数组导入变量表(关联键为变量名)
mysql_query("set names 'GB2312'"); 用于通知 mysql 以后的交互以 GB2312 字符集进行
通常在连接数据库以后执行一次就可以了
由
if($number1 echo"
人数不能少于现已选题人数,人数列修改失败!";
可知 sn 为备选人数, ssn 已选人数
无过滤条件查询
select count(*) as sm from keti
有过滤条件查询
select count(*) as sm from keti where surplus='$surplus'
$where = (isset($surplus) && strlen($surplus)>0) ? " where surplus='$surplus'" : '';这一句最不懂
$where = (isset($surplus) && strlen($surplus)>0) ? " where surplus='$surplus'" : '';
三元运算,等价于
if(isset($surplus) && strlen($surplus)>0)) {
$where = " where surplus='$surplus'";
}else {
$where = '';
}

PHP在现代编程中仍然是一个强大且广泛使用的工具,尤其在web开发领域。1)PHP易用且与数据库集成无缝,是许多开发者的首选。2)它支持动态内容生成和面向对象编程,适合快速创建和维护网站。3)PHP的性能可以通过缓存和优化数据库查询来提升,其广泛的社区和丰富生态系统使其在当今技术栈中仍具重要地位。

在PHP中,弱引用是通过WeakReference类实现的,不会阻止垃圾回收器回收对象。弱引用适用于缓存系统和事件监听器等场景,需注意其不能保证对象存活,且垃圾回收可能延迟。

\_\_invoke方法允许对象像函数一样被调用。1.定义\_\_invoke方法使对象可被调用。2.使用$obj(...)语法时,PHP会执行\_\_invoke方法。3.适用于日志记录和计算器等场景,提高代码灵活性和可读性。

Fibers在PHP8.1中引入,提升了并发处理能力。1)Fibers是一种轻量级的并发模型,类似于协程。2)它们允许开发者手动控制任务的执行流,适合处理I/O密集型任务。3)使用Fibers可以编写更高效、响应性更强的代码。

PHP社区提供了丰富的资源和支持,帮助开发者成长。1)资源包括官方文档、教程、博客和开源项目如Laravel和Symfony。2)支持可以通过StackOverflow、Reddit和Slack频道获得。3)开发动态可以通过关注RFC了解。4)融入社区可以通过积极参与、贡献代码和学习分享来实现。

PHP和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

PHP不是在消亡,而是在不断适应和进化。1)PHP从1994年起经历多次版本迭代,适应新技术趋势。2)目前广泛应用于电子商务、内容管理系统等领域。3)PHP8引入JIT编译器等功能,提升性能和现代化。4)使用OPcache和遵循PSR-12标准可优化性能和代码质量。

PHP的未来将通过适应新技术趋势和引入创新特性来实现:1)适应云计算、容器化和微服务架构,支持Docker和Kubernetes;2)引入JIT编译器和枚举类型,提升性能和数据处理效率;3)持续优化性能和推广最佳实践。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

记事本++7.3.1
好用且免费的代码编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

SublimeText3 Linux新版
SublimeText3 Linux最新版