Jadual Kandungan
回复讨论(解决方案)
Rumah pembangunan bahagian belakang tutorial php 【明天毕业设计答辩,好紧张,求各路版主保佑】

【明天毕业设计答辩,好紧张,求各路版主保佑】

Jun 23, 2016 pm 02:11 PM

我做的是一个毕业设计选题系统,现在在熟悉代码。我知道哪个功能是通过哪段代码实现的,但是代码的具体含义我很模糊。望高手帮我在旁边注释在后边~~
由于我的这个项目是旧的基础上修改添加的部分功能,所以有时必须添加

extract($_POST);
Salin selepas log masuk
或者
extract($_REQUEST);
Salin selepas log masuk
才能运行一些功能,这是什么意思?
还有就是,我每一段执行数据库的代码后边都要跟这么几句
$query="select * from $student_table where xuehao='$xuehao'";	mysql_query("set names 'GB2312'");	$result=mysql_query($query);	$row=mysql_fetch_array($result);
Salin selepas log masuk

还有这是修改课题的一段,我就不知道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;				 }
Salin selepas log masuk

这是下载资料的一段代码
$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);  }
Salin selepas log masuk

尤其是最后这段关于“可选”与“不可选”表单的,不懂
$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");
Salin selepas log masuk


回复讨论(解决方案)

extract 将数组导入变量表(关联键为变量名)

mysql_query("set names 'GB2312'"); 用于通知 mysql 以后的交互以 GB2312 字符集进行
通常在连接数据库以后执行一次就可以了


if($number1<($row['sn']-$row['ssn'])) {
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<($row['sn']-$row['ssn'])) {
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'" : ''; 
Salin selepas log masuk
这一句最不懂

$where = (isset($surplus) && strlen($surplus)>0) ? " where surplus='$surplus'" : '';
三元运算,等价于
if(isset($surplus) && strlen($surplus)>0)) {
  $where = " where surplus='$surplus'";
}else {
  $where = '';
}

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Terangkan konsep pengikatan statik lewat dalam PHP. Terangkan konsep pengikatan statik lewat dalam PHP. Mar 21, 2025 pm 01:33 PM

Artikel membincangkan pengikatan statik lewat (LSB) dalam PHP, yang diperkenalkan dalam Php 5.3, yang membolehkan resolusi runtime kaedah statik memerlukan lebih banyak warisan yang fleksibel. Isu: LSB vs polimorfisme tradisional; Aplikasi Praktikal LSB dan Potensi Perfo

Ciri -ciri Keselamatan Rangka Kerja: Melindungi Kelemahan. Ciri -ciri Keselamatan Rangka Kerja: Melindungi Kelemahan. Mar 28, 2025 pm 05:11 PM

Artikel membincangkan ciri -ciri keselamatan penting dalam rangka kerja untuk melindungi daripada kelemahan, termasuk pengesahan input, pengesahan, dan kemas kini tetap.

Menyesuaikan/Memperluas Rangka Kerja: Cara Menambah Fungsi Custom. Menyesuaikan/Memperluas Rangka Kerja: Cara Menambah Fungsi Custom. Mar 28, 2025 pm 05:12 PM

Artikel ini membincangkan menambah fungsi khusus kepada kerangka kerja, memberi tumpuan kepada pemahaman seni bina, mengenal pasti titik lanjutan, dan amalan terbaik untuk integrasi dan debugging.

Bagaimana cara menghantar permintaan pos yang mengandungi data JSON menggunakan perpustakaan php curl? Bagaimana cara menghantar permintaan pos yang mengandungi data JSON menggunakan perpustakaan php curl? Apr 01, 2025 pm 03:12 PM

Menghantar data JSON menggunakan perpustakaan Curl PHP dalam pembangunan PHP, sering kali perlu berinteraksi dengan API luaran. Salah satu cara biasa ialah menggunakan perpustakaan curl untuk menghantar post ...

Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Huraikan prinsip -prinsip yang kukuh dan bagaimana ia memohon kepada pembangunan PHP. Apr 03, 2025 am 12:04 AM

Penerapan prinsip pepejal dalam pembangunan PHP termasuk: 1. Prinsip Tanggungjawab Tunggal (SRP): Setiap kelas bertanggungjawab untuk hanya satu fungsi. 2. Prinsip Terbuka dan Tutup (OCP): Perubahan dicapai melalui lanjutan dan bukannya pengubahsuaian. 3. Prinsip Penggantian Lisch (LSP): Subkelas boleh menggantikan kelas asas tanpa menjejaskan ketepatan program. 4. Prinsip Pengasingan Antara Muka (ISP): Gunakan antara muka halus untuk mengelakkan kebergantungan dan kaedah yang tidak digunakan. 5. Prinsip Inversi Ketergantungan (DIP): Modul peringkat tinggi dan rendah bergantung kepada abstraksi dan dilaksanakan melalui suntikan ketergantungan.

Apa sebenarnya ciri yang tidak menyekat ReactPhp? Bagaimana untuk mengendalikan operasi I/O yang menyekatnya? Apa sebenarnya ciri yang tidak menyekat ReactPhp? Bagaimana untuk mengendalikan operasi I/O yang menyekatnya? Apr 01, 2025 pm 03:09 PM

Pengenalan rasmi kepada ciri yang tidak menyekat ReactPhp yang mendalam tafsiran mengenai ciri-ciri yang tidak menyekat ReactPhp telah menimbulkan banyak soalan pemaju: "ReactPhpisnon-blockingbydefault ...

See all articles