v2.5.2
Giriş yap

Aynı anda birden fazla tabloya kayıt etmek

Anonim
666 defa görüntülendi

Post ile gelen verileri aynı anda birden fazla tabloya kaydetmek için aşağıdaki gibi bir kod yazdım ancak ilk başta bulunan $ekle çalışmıyor dierkt iflerin içerisindekiler çalışıyor. $ekle yi if parantezlerinin içerisine yazıpta denemiştim yine olmuyordu onun yerine oekle ve pekle çalışıyor. Ne yapabilirim?

<?php
    
$ekle = "INSERT into genel (baslik,aciklama,adres,logo,etiket) values('$baslik','$aciklama','$padres','$ad','$etiket')";


if($tur==$oyun) {

rename('../admin/'.$sadi.'', '../games/'.$sadi.'');

$oekle = "INSERT into oyunlar (baslik,aciklama,adres,logo,etiket) values('$baslik','$aciklama','$adres','$ad','$etiket')";

if($connect->query($oekle)) {
  echo "Başarıyla Eklendi. 5 Saniye İçerisinde Yönetim Sayfasına Yönlendirileceksiniz.";
  header("Refresh: 5; url=yonetim.php");
}
else {
  echo "Bir hata oluştu! Maalesef İşlem Tamamlanamadı :/";
  header("Refresh: 5; url=yonetim.php");
}
}

elseif($tur==$program) {

rename('../admin/'.$sadi.'', '../programs/'.$sadi.'');

$pekle = "INSERT into programlar (baslik,aciklama,adres,logo,etiket) values('$baslik','$aciklama','$adres','$ad','$etiket')";

if($connect->query($pekle)) {
  echo "Başarıyla Eklendi. 5 Saniye İçerisinde Yönetim Sayfasına Yönlendirileceksiniz.";
  header("Refresh: 5; url=yonetim.php");
}
else {
  echo "Bir hata oluştu! Maalesef İşlem Tamamlanamadı :/";
  header("Refresh: 5; url=yonetim.php");
}
?>
m100
1393 gün önce

birdan fazla tabloya kayıt için PDO'da çok güzel fonksiyonlarımız var aslında arkadaşların verdiği cevaplar da işe yarayabilir fakat her zaman hazır PDO fonksiyonlar hem daha güvenli hem daha kolay olur genelde


/* Ototeslim kipini kapatıp bir hareket başlatalım */
$dbh->beginTransaction();

/* Veritabanı şemasını ve verisini değiştirelim */
$sth = $dbh->exec("DROP TABLE fruit");
$sth = $dbh->exec("UPDATE dessert
    SET name = 'hamburger'");

/* değişikliği gönderiyoruz */
$dbh->commit();

Fakat bu şekilde kullanman için PDO bağlantında bğazı değiştikler yapıp attr eklemen gerekiyor
ve toplu paket yüklerken her zmaan try catch içine al ve şu kodu yaz

/* bu kod bir hata var ise yaprığın değikiklikleri geri almana yarar */
$dbh->rollBack();

bağlantında yapman gereken değişklik ise şu

array(PDO::ATTR_PERSISTENT => true)
/* bu kodu PDO bağlantı cümlenin sonuna , ile ekle  */