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