我有一个网页,我在其中上传了一个 csv 文件,然后使用 php
将其导入到mysql数据库中。
我有一个 mysql 查询,"SELECT * FROM wifi"
然后计算数据库中的行数。然后它应该运行 csv 的导入并进行相同的查询并再次计算行数,向我显示“之前和之后”的数字。这我开始工作了,有点。
问题是,计算“之前”数字的第一个查询位于页面顶部,它显示的数字很好,当我点击提交按钮时,它将我的 csv 发送到 php 中,将其插入数据库并重定向到"pagehere?success=1"
哪里它应该告诉我“之后”的数字。但是随着页面重新加载/重定向,带有“之前”编号的第一个查询将重新运行并显示“之后”编号。
所以我有一个“之前”数字,导入 csv 和页面重新加载,然后我有两个“之后”数字。
如何在页面重定向期间保留“之前”编号?
代码是这样的(我还在学习,可能有问题)
(THIS CODE IS IN WEBPAGE)
//Count before import
$before = mysql_query("SELECT * FROM wifi");
$num_rows_before = mysql_num_rows($before);
(THIS CODE IS WHERE THE FORM UPLOAD FILE TO AFTER SUBMIT-BUTTON)
<?php
if ($_FILES[csv][size] > 0) {
//get the csv file
$file = $_FILES[csv][tmp_name];
$handle = fopen($file,"r");
//loop through the csv file and insert into database
do {
if ($data[0]) {
mysql_query("INSERT IGNORE INTO wifi (bssid, channel, privacy, ciper, auth, power, essid, latitude, longitude, first_seen, last_seen) VALUES
(
'".addslashes($data[0])."',
'".addslashes($data[1])."',
'".addslashes($data[2])."',
'".addslashes($data[3])."',
'".addslashes($data[4])."',
'".addslashes($data[5])."',
'".addslashes($data[6])."',
'".addslashes($data[7])."',
'".addslashes($data[8])."',
'".addslashes($data[9])."',
'".addslashes($data[10])."'
)
");
}
} while ($data = fgetcsv($handle,1000,","));
//redirect
header('Location: index.php/upload?success=1'); die;
}
//Count after import
$after = mysql_query("SELECT * FROM wifi");
$num_rows_after = mysql_num_rows($after);
//echo stats
echo "Number of rows before - ";
echo "$num_rows_before";
<br>
echo "Number of rows after - ";
echo "$num_rows_after";
//generic success notice
if (!empty($_GET[success])) { echo "<br><b>Result: Your file is imported!</b><br>"; }
//Close connection to databse
mysql_close($connect) ;
?>