微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

帮助编写查询

如何解决帮助编写查询

| 我有一个看起来像的csv文件   手机短信   手机短信   手机短信 我有一个数据库表   ID,移动   ID,移动   ID,移动 我正在使用
fgetcsv
将csv读入数组。 我要结束的是一个看起来像的数组 手机,消息,身份证 手机,消息,身份证 手机,消息,身份证 我可以做的一个查询是 数组中的foreach行做
select id from table where mobile = ...;
但是看到有2000行会变得凌乱, 有什么更好的方法?     

解决方法

如果您想用PHP而不是数据库来完成此操作(如@Ignacio所建议),则有以下可能性:
/* ... $array = fgetcsv ... */

$mobiles = array_unique(array_map(create_function(\'$a\',\'return $a[\"mobile\"];\'),$array));
$mobiles = array_map(\'mysql_real_escape_string\',$mobiles);

$query = \"SELECT `id`,`mobile` FROM `table`
          WHERE `mobile` IN (\'\" . join(\"\',\'\",$mobiles) . \"\')\";

/* ... $mobiles = mysql_query ... */

foreach ($array as &$row) {
    foreach ($mobiles as $mobile) {
        if ($row[\'mobile\'] == $mobile[\'mobile\']) {
            $row[\'id\'] = $mobile[\'id\'];
            continue 2;
        }
    }
}
    ,将CSV文件加载到数据库中,然后在两个表上进行联接。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。