Forum

php mysql kayitlari...
 
Bildirimler
Hepsini Temizle

php mysql kayitlarin toplu olarak guncellenmesi

2 Yazılar
2 Üyeler
0 Reactions
1,240 Görüntüleme
(@phantoma)
Gönderiler: 6
Active Member
Konu başlatıcı
 

Merhaba  nette bulunan  asagidaki kodu editledim, veri tabinindan mevcutlari cekip goruntuluyor ve mevcutlar degistirilerek submit edildiginde DB'yi guncellemesi gerekiyor fakat bu mevcut bilgileri geri donduruyor yani guncelleme islemi gerceklesmiyor yardimci olabilirseniz sevinirim, 

<strong>Update multiple rows in mysql</strong><br>

<?php
$host="localhost"; // Host name
$username=""; // Mysql username
$password=""; // Mysql password
$db_name="test"; // Database name
$tbl_name="test_mysql"; // Table name

// Connect to server and select databse.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");

$sql="SELECT * FROM $tbl_name";
$result=mysql_query($sql);

// Count table rows
$count=mysql_num_rows($result);
?>
<table width="500" border="0" cellspacing="1" cellpadding="0">
<form name="form1" method="post" action="">
<tr>
<td>
<table width="500" border="0" cellspacing="1" cellpadding="0">

<tr>
<td align="center"><strong>Id</strong></td>
<td align="center"><strong>Name</strong></td>
<td align="center"><strong>Lastname</strong></td>
<td align="center"><strong>Email</strong></td>
</tr>
<?php
while($rows=mysql_fetch_array($result)){
?>
<tr>
<td align="center"><? $id[]=$rows['id']; ?><? echo $rows['id']; ?></td>
<td align="center"><input name="name[]" type="text" id="name" value="<? echo $rows['name']; ?>"></td>
<td align="center"><input name="lastname[]" type="text" id="lastname" value="<? echo $rows['lastname']; ?>"></td>
<td align="center"><input name="email[]" type="text" id="email" value="<? echo $rows['email']; ?>"></td>
</tr>
<?php
}
?>
<tr>
<td colspan="4" align="center"><input type="submit" name="Submit" value="Submit"></td>
</tr>
</table>
</td>
</tr>
</form>
</table>
<?php
// Check if button name "Submit" is active, do this
if($Submit){
for($i=0;$i<$count;$i++){
$sql1="UPDATE $tbl_name SET name='$name[$i]', lastname='$lastname[$i]', email='$email[$i]' WHERE id='$id[$i]'";
$result1=mysql_query($sql1);
}
}

if($result1){
header("location:update_multiple.php");

 
Gönderildi : 19/01/2011 02:14

(@ferhatkaratas)
Gönderiler: 100
Estimable Member
 

Makinamda php ve mysql kurulu değil. bu sebeple test edemiyorum. ama yukarıdaki kodlardan yola çıkarak bir şeyler söylemeye çalışayım. 

while ifadesinden sonra form kontrollerine verilen id lerde problem var gibi görünüyor. mesela ilk satırdaki id yi, hidden field olarak belirtin. sonraki td lerin içine de o anki id yi basın. şöyle ki;

 

<?php

$player_id=$rows['id'];

 ?>

<td><input type="hidden" name="p_id['.$player_id.']" value="'.$player_id.'"><? echo $rows['id']; ?></td>
'<td><input name="name['.$player_id.']" type="text" id="name['.$player_id.']"><? echo $rows['name']; ?></td>

 
Gönderildi : 19/01/2011 12:44

Paylaş: