dongzai3917 2015-06-26 14:50
浏览 32
已采纳

将foreach作为数组提交给MySQL

I am needing away to insert data to a database based on an auto generated list from a form.

So I have this that lists out the key and value, but I need to create an array that I can then use a $sql insert to database.

foreach ($_POST as $key => $value) {
        if($value != "") {
            print $key.": ".$value . "<br>";
        }
}

So then I have this for $sql insert

$sql = "INSERT INTO FDPU ($key) VALUES ('$value')";
if ($conn->query($sql) === TRUE) {
echo $key.'='.$value.'New record created successfully'.'<br />';
} else {
echo "Error: " . $sql . "<br>" . $conn->error;
}
  • 写回答

1条回答 默认 最新

  • duanji5569 2015-06-26 15:00
    关注

    Not tested, but something like this should do it:

    $keys = array();
    $values = array();
    
    foreach ($_POST as $key => $value) {
            if($value != "") {
                $keys[] = $key;
                $values[] = "'" . $value . "'";
            }
    }
    
    $sql = "INSERT INTO FDPU (" . implode(',', $keys) . ") VALUES (" . implode(',', $values) . ")";
    

    It stores the keys and values of the variables that are not empty, and then put them together using the very handy function implode.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据