doufeng3602 2015-12-08 19:21
浏览 59
已采纳

使用括号填充数组值以执行插入

I want to have each array value inside a paranthesis

$id   = $_POST['id'];
$test2 = array($id);
$id_list = implode(',', $test2);
$sql .= "INSERT INTO tmp (id) VALUES ({$id_list});";

for example: I'm performing an insert so the output of the list should be (5),(10),(15) not '5','10','15'

Any suggestions on how I can insert using an array?

  • 写回答

1条回答 默认 最新

  • doudu2515 2015-12-08 19:30
    关注

    MySQL's extended insert syntax is

    INSERT INTO sometable (...fields...) VALUES (value set #1), (value set #2), (value set #3), etc...
    

    Note how each value set is in its own (). You're not doing that. you're just passing a bunch of values in a SINGLE () set, which means you're providing values for fields that are NOT present in the field list.

    You need to do

    $id_list = '(' . implode('),(', $_POST['id']) . ')';
    

    producing

    (5),(10),(15)
    

    instead of

    (5, 10, 15)
    

    You also need to realize that you're vulnerable to sql injection attacks.

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

报告相同问题?

悬赏问题

  • ¥50 易语言把MYSQL数据库中的数据添加至组合框
  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况