doujiao1949 2013-09-02 16:44
浏览 44
已采纳

ajax动态对象(关联数组)通过PDO分成两个MySQL表

I have a js dynamic object that I "stringified" via JSON.stringify(obj_to_str);

I'm able to receive this object in a php file under the super-global $_POST. The object's format (once in the $_POST super-global) looks like this: {"6869lx":"mds","2416ex":"mdr","5126mv":"mdf","7079px":"dtr","5350ds":"dts"}. I'd like to be able to insert each key-value pare into a different column -for instance: 6869lx into a column called 'key', and on the same row on a different column called 'cat', mds.

The problem I'm having is to prepare a dynamic PDO statement to insert this js object into two different MySQL columns (considering the fact that I do not know the length of the object before-hand). I also read that if the object is very large a for loop (or any type of php loop) would slow down the insertion process.

Is it possible ? What would be the best way of doing it? Thanks much in advance.

  • 写回答

1条回答 默认 最新

  • duanmao9918 2013-09-02 17:29
    关注

    Here's how you do it:

    $data = json_decode($_POST['data'], true);
    $stmt = $pdo->prepare("INSERT INTO yourtable (key, cat) VALUES (:key, :cat)");
    $stmt->bindParam(':key', $key);
    $stmt->bindParam(':cat', $cat);
    foreach ($data as $key => $cat) {
        $stmt->execute();
    }
    

    To do a multi-row insert, you can do:

    $data = json_decode($_POST['data'], true);
    $values = implode(', ', array_fill(0, count($data), '(?, ?)'));
    $stmt = $pdo->prepare("INSERT INTO yourtable (key, cat) VALUES " . $values);
    $i = 1;
    foreach ($data as $key => $cat) {
        $stmt->bindValue($i++, $key);
        $stmt->bindValue($i++, $cat);
    }
    $stmt->execute();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 matlab实现基于主成分变换的图像融合。
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊