duanrenzou1619 2013-07-04 18:35
浏览 32
已采纳

如果不选择整个数据库并与PHP进行比较,如何获得数据库中尚未存在的ID

I have an array of ID's that correlate to a unique column in a MySQL table, is there a way to get the ID's from the array that don't appear in the database? I know I could do it by selecting the entire database and doing comparisons with PHP, but the table could get pretty big, so this doesn't seem like a very good idea to me.

  • 写回答

6条回答 默认 最新

  • doujing6053 2013-07-04 21:33
    关注

    Do it in two stages:

    $ids = implode(',', $your_array);
    
    SELECT id FROM thetable WHERE id IN ($ids); 
    
    $found_ids = array();
    while($row = fetch($result)) {
        $found_ids[] = $row['id'];
    }
    
    $missing = array_diff($your_array, $found_ids);
    

    Basically: use your array of ids to select any matching records from the DB. Any ids in the array which don't have matching records will obviously not be returned. Take that result set, stuff it into another array. Then do a diff between the two arrays. The missing values will pop out as they'll only be in the original array, not the "found" one.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥20 模型在y分布之外的数据上预测能力不好如何解决
  • ¥15 processing提取音乐节奏
  • ¥15 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序
  • ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
  • ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
  • ¥15 opencv图像处理,需要四个处理结果图
  • ¥15 无线移动边缘计算系统中的系统模型
  • ¥15 深度学习中的画图问题
  • ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条