mysql update语句运行无错误但是没有更新

<?php
$link = mysql_connect("localhost", "root", "20050608");
mysql_select_db("leenkon", $link);
$result = mysql_query("SELECT * FROM jzjy where qqnum='109914256' order BY 'times' DESC", $link);
$num_rows = mysql_num_rows($result);
$row = mysql_fetch_array($result);
echo "共计".$num_rows."行结果<br />\n";
for ($i = mysql_num_rows($result) - 1; $i >= 0; $i--) {
if (!mysql_data_seek($result, $i)) {
echo "Cannot seek to row $i: " . mysql_error() . "\n";
continue;
}
if (!($row = mysql_fetch_assoc($result))) {
continue;
}
$j=intval($i);
$a=mysql_query("UPDATE jzjy SET ids='$j' where qqnum='109914256'");//这一句目的是将表中的一个字段ids修改为$i的值,程序没有报错。。。但是没有更新成功
echo $row['id'] . ' ' . $row['ids'] . "<br />\n";
echo $a;
}

mysql_close($link);

?>

ids或者qqnum在你数据库是什么类型的字段名?
要是字符型(varchar,char等),单引号是对的

要是整形(int等)型就不对了,整形是不用引号的。

执行没有错不代表SQL语句没错

你可以这样写:
<?php
//上面程序略...
$a=mysql_query("UPDATE jzjy SET ids='$j' where qqnum='109914256'");
//执行
if($a)//执行成功
echo '修改成功'.'<br>';
else//否则
echo '对不起,修改失败,出错信息是:'.mysql_error().'<br>';
//提示mysql_query的报错信息,你自己根据信息找错误,不然可以问我
//..下面程序略...
?>
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-08-11
ids 原来的值是什么?0?如果是0,这次$j=intval($i);的$j也是0的话,就会没有更新到,你可以输出SQL看看是否正确
echo "UPDATE jzjy SET ids='$j' where qqnum='109914256'";
exit();追问

UPDATE jzjy SET ids='3' where qqnum='109914256'
UPDATE jzjy SET ids='2' where qqnum='109914256'
UPDATE jzjy SET ids='1' where qqnum='109914256'

输出来的结果是这样的,说明是没有错的呢

第2个回答  2011-08-16
没有"事务提交"吧!!