Ben bir dizi bind() koÅŸul?
Mümkünse tutucu kullanarak bir PDO değerler dizisi bağlamak olduğunu merak ediyorum. Kullanın diye burada IN() bir durum ile kullanmak için bir değer dizisi geçirmeye çalışıyor.
Anlatma konusunda pek iyi değilim, buraya göstermek için bazı psuedocode. Böyle bir şey yapmak mümkün olmak istiyorum
<?php
$ids=array(1,2,3,7,8,9);
$db = new PDO(...);
$stmt = $db->prepare(
'SELECT *
FROM table
WHERE id IN(:an_array)'
);
$stmt->bindParam('an_array',$ids);
$stmt->execute();
?>
Ve PDO bağlama ve dizideki tüm değerleri belirtiniz.
Şu an yapıyorum:
<?php
$ids = array(1,2,3,7,8,9);
$db = new PDO(...);
foreach($ids as &$val)
$val=$db->quote($val); //iterate through array and quote
$in = implode(',',$ids); //create comma separated list
$stmt = $db->prepare(
'SELECT *
FROM table
WHERE id IN('.$in.')'
);
$stmt->execute();
?>
Hangi kesinlikle iş yapar, ama sadece eğer kaçırıyorum yerleşik bir çözümü var mı diye soracaktım?
CEVAP
soulmerge doğru olduğunu düşünüyorum. sorgu dizesi inşa etmek zorundasınız.
<?php
$ids = array(1, 2, 3, 7, 8, 9);
$inQuery = implode(',', array_fill(0, count($ids), '?'));
$db = new PDO(...);
$stmt = $db->prepare(
'SELECT *
FROM table
WHERE id IN(' . $inQuery . ')'
);
// bindvalue is 1-indexed, so $k 1
foreach ($ids as $k => $id)
$stmt->bindValue(($k 1), $id);
$stmt->execute();
?>
düzeltme:dan, sen haklıydın. sabit kod (gerçi test etmedim)
düzenleme:(yorum) hem chris ve somebodyisintrouble bu döngü dosyalarda grup olduğunu söylemişti
(...)
// bindvalue is 1-indexed, so $k 1
foreach ($ids as $k => $id)
$stmt->bindValue(($k 1), $id);
$stmt->execute();
... gereksiz olabilir, foreach döngü $stmt->execute sadece yerini olabilir
<?php
(...)
$stmt->execute($ids);
?>
(tekrar test) bilmiyordum

Nasıl $Sony kullanıyorsunuz.çoğaltmak ...
Nasıl PHP çok boyutlu bir dizi anahtar...
Co-değişken y için x dizi dönüşüm zama...
Anahtarları bir Dizi dayalı bir Dizi s...
Nasıl bir H264 x264 C API kullanarak b...