2
请解释一下我为什么代码:PHP - 通过克隆复制类 - 是这个错误或即时做错了吗?
class kategoria
{
public $IdKat;
public $NazwaKat;
public $OpisKat;
}
class dbClass
{
private $link;
private $user = USER;
private $pass = PASS;
private $database = DATABASE;
function __construct()
{
try
{
$this->link = new mysqli('localhost', $this->user, $this->pass, $this->database);
$this->link->set_charset('utf8');
;
}
catch(Exception $exc)
{
echo $e;
}
}
function get_cats()
{
$query = "SELECT IdKat, NazwaKat, OpisKat FROM `kategorie`";
try
{
$stmt = $this->link->prepare($query);
/* bind parameters for markers */
//$stmt->bind_param("i", $IdKat);
$stmt->execute();
$kat = new kategoria();
$stmt->bind_result(
$kat->IdKat,
$kat->NazwaKat,
$kat->OpisKat
);
$output = array();
$output2 = array();
while ($stmt->fetch()) {
array_push($output, $kat->IdKat);
array_push($output2, $kat);
// array_push($output2, clone $kat); // i tried cloning like this
// $output2 += array(clone($kat)); // tried adding
}
$stmt->close();
}
catch (Exception $e)
{
echo $e;
}
echo '<pre>';
print_r($output);
echo '</pre>';
echo '--------------------------<br/>';
echo '<pre>';
print_r($output2);
echo '</pre>';
}
}
使我的数据是这样的:
Array (
[0] => 2
[1] => 3
[2] => 4)
--------------------------
Array (
[0] => kategoria Object
(
[IdKat] => 4
[NazwaKat] => Hi-Fi
[OpisKat] => Music equipment
)
[1] => kategoria Object
(
[IdKat] => 4
[NazwaKat] => Hi-Fi
[OpisKat] => Music equipment
)
[2] => kategoria Object
(
[IdKat] => 4
[NazwaKat] => Hi-Fi
[OpisKat] => Music equipment
)
)
这是我关于它的第二个问题。我尝试添加数组,克隆对象$ kat,但它没有奏效。最后我做了另一个数组,并使用两者进行调试。
它看起来很奇怪。我不明白为什么在数组中克隆的对象在下一行读取后被覆盖。它应该是他克隆的副本,对吧?
这里最大的问题是为什么使用bind_result,而您可以通过使用fetch_object创建单个对象。 – 2012-07-10 12:54:47
也许这是错误的做法,我没有经历过MySQL/PHP编程。我试图用更“现代”的方法。我已阅读关于MySQL帮助中的绑定结果。 – Kamil 2012-07-11 15:32:41