问题描述
|
我有一个看起来像的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文件加载到数据库中,然后在两个表上进行联接。