我取出数据库中不同表中相同字段的值分别两个不同的数组中,使用array_diff(),找出在数组1而不在数组2的的元素,为何只返回一个不同的元素?
代码如下:
error_reporting( E_ALL&~E_NOTICE );
header('Content-type:text/html; charset=utf-8');
date_default_timezone_set('Asia/Shanghai');
require_once("init.php");
$sql="select * from dev_property";
$res=mysql_query($sql) or die(mysql_error());
$num_rows=mysql_num_rows($res);
while($sn=mysql_fetch_array($res))
{
$prime=array();
$prime[]=$sn["serial_number"];
for($i=0;$i
echo $prime[$i];
echo "";
}
}
echo "";
$starttime = '08:25:00';
$endtime = '23:35:00';
$sql="select * from data where time>='".date('Y-m-d').' '.$starttime."' and time $result=mysql_query($sql) or die(mysql_error());
while($date=mysql_fetch_array($result))
{
// $num_rows1=mysql_num_rows($result);
$a=array();
$a[]=$date["serial_number"];
for($i=0;$i
echo $a[$i];
echo "";
}
echo "";
}
$diff=array_diff($prime,$a);
for($i=0;$i
echo "";
echo count($diff);
echo "";
?>
执行结果:
数组$prime
862118028862461
862118028862462
862118028862463
862118028862464
数组$a
862118028862461
结果
862118028862464
1
按照我的本意返回的应该是
862118028862462
862118028862463
862118028862464
现在只返回了862118028862464,为什么?
你在 $diff=array_diff($prime,$a); 前打印一下数组
print_r($prime);print_r($a);$diff=array_diff($prime,$a);
你在 $diff=array_diff($prime,$a); 前打印一下数组
print_r($prime);print_r($a);$diff=array_diff($prime,$a);
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号