delete from test;
删掉test表中所有记录没有运行成功可能是表单提交没有用$_POST['submit'].
if (isset($_POST['submit'].)) {

解决方案 »

  1.   

    foreach是什么意思啊,好像PHP里没有这个函数
      

  2.   

    我也不知道foreach是什么意思!我还不懂$submit什么意思?是不是前一页的type=submit来的?刚才试过了$_POST['submit']也没用!
      

  3.   

    哦,对不起,刚才少写了个; 唉!可以显示了可是echo出来的delete from keda_news where news_id='Array' 
    前一页的html:<input name="selectdel[]" type="checkbox" value=<?echo $row["news_id"]?>>执行的php:
    <?
    $submit = $HTTP_POST_VARS['submit'];
    $news_id = $HTTP_POST_VARS["selectdel"];
    if (isset($submit)) {
      foreach($news_id as $val) {
    $query="delete from keda_news where news_id='$news_id'";
    echo $query."<br>";
    //mysql_query($query) or die(mysql_error());
    }
    }
    ?>
      

  4.   

    hoho,可能是急昏了,竟然传的变量都写错了!搞定了!谢谢!
      

  5.   

    这个和你提交页面有关系啊!你提交页面的ID是一个数组,id是每条记录的序号,而当 foreach 开始执行时,数组内部的指针会自动指向第一个单元。然后把每个元素赋值给$val
    原语句是没有错误的,只是你提交页面的问题!
      

  6.   

    他的执行原理我是知道的。可是我不明白foreach(参数)明明是个函数的,怎么执行起来不用调用呢??
      

  7.   

    foreach
    PHP 4(不是 PHP 3)包括了 foreach 结构,和 Perl 以及其他语言很像。这只是一种遍历数组简便方法。foreach 仅能用于数组,当试图将其用于其它数据类型或者一个未初始化的变量时会产生错误。有两种语法,第二种比较次要但却是第一种的有用的扩展。 
    foreach(array_expression as $value) statement
    foreach(array_expression as $key => $value) statement
     第一种格式遍历给定的 array_expression 数组。每次循环中,当前单元的值被赋给 $value 并且数组内部的指针向前移一步(因此下一次循环中将会得到下一个单元)。 第二种格式做同样的事,只除了当前单元的键值也会在每次循环中被赋给变量 $key。 
    注: 当 foreach 开始执行时,数组内部的指针会自动指向第一个单元。这意味着不需要在 foreach 循环之前调用 reset()。 注: 此外注意 foreach 所操作的是指定数组的一个拷贝,而不是该数组本身。因此即使有 each() 的构造,原数组指针也没有变,数组单元的值也不受影响。 
    注: foreach 不支持用“@”来禁止错误信息的能力。 你可能注意到了以下的代码功能完全相同: 
    $arr = array("one", "two", "three");
    reset ($arr);
    while (list(, $value) = each ($arr)) {
        echo "Value: $value<br>\n";
    }foreach ($arr as $value) {
        echo "Value: $value<br>\n";
    }
     
    以下代码功能也完全相同: reset ($arr);
    while (list($key, $value) = each ($arr)) {
        echo "Key: $key; Value: $value<br>\n";
    }foreach ($arr as $key => $value) {
        echo "Key: $key; Value: $value<br>\n";
    }
     示范用法的更多例子: 
    /* foreach example 1: value only */$a = array (1, 2, 3, 17);foreach ($a as $v) {
       print "Current value of \$a: $v.\n";
    }/* foreach example 2: value (with key printed for illustration) */$a = array (1, 2, 3, 17);$i = 0; /* for illustrative purposes only */foreach($a as $v) {
        print "\$a[$i] => $v.\n";
        $i++;
    }/* foreach example 3: key and value */$a = array (
        "one" => 1,
        "two" => 2,
        "three" => 3,
        "seventeen" => 17
    );foreach($a as $k => $v) {
        print "\$a[$k] => $v.\n";
    }/* foreach example 4: multi-dimensional arrays */$a[0][0] = "a";
    $a[0][1] = "b";
    $a[1][0] = "y";
    $a[1][1] = "z";foreach($a as $v1) {
        foreach ($v1 as $v2) {
            print "$v2\n";
        }
    }/* foreach example 5: dynamic arrays */foreach(array(1, 2, 3, 4, 5) as $v) {
        print "$v\n";
    }
     
      

  8.   

    循环删除对数据库的开销很大可以把$_POST[selectdel]这样处理下:$news_id=join(",",$_POST[selectdel]);mysql_query("delete from keda_news where news_id in '".$news_id."'");ps:PHP4就开始支持foreach
      

  9.   

    上面有误:
    mysql_query("delete from keda_news where news_id in (".$news_id.")");btw:你的news_id是varchar类型的?
      

  10.   

    news_id 是自动编号!int类型,可以吗?感谢各位!
      

  11.   

    当然可以:$news_id=join(",",$_POST[selectdel]);mysql_query("delete from keda_news where news_id in (".$news_id.")");就行了
      

  12.   

    谢谢北风,您这种方法对数据量大的确实很好!感谢ing....!可以结贴了!:)