我正在尝试为我的 mysqli 连接编写一个非常小的抽象层并且遇到了问题。由于我正在维护旧代码,我需要从我的查询中获取一个关联数组,因为这是代码的设置方式,因此一旦它工作对我来说工作量就会减少......这个函数适用于所有类型的查询(不是只需选择)...
我写的函数是这样的:
function connectDB($query,$v=array()) {
$mysqli = new mysqli(HOST,USER,PW,DATABASE);
if($res=$mysqli->prepare($query)) {
//dynamically bind all $v
if($v) {
$values=array($v[0]);
for($i=1; $i<count($v); $i++) {
${'bind'.$i}=$v[$i];
$values[]=&${'bind'.$i};
}
call_user_func_array(array($res,'bind_param'),$values);
}
$res->execute();
//bind all table rows to result
if(strtolower(substr($query,0,6))=="select") {
$fields=array();
$meta=$res->result_metadata();
while($field=$meta->fetch_field()) {
${$field->name}=null;
$fields[$field->name]=&${$field->name};
}
call_user_func_array(array($res,"bind_result"),$fields);
//return associative array
$results = array();
$i=0;
while($res->fetch()) {
$results[$i]=array();
foreach($fields as $k => $v) $results[$i][$k] = $v;
$i++;
}
}
else {
$results=$mysqli->affected_rows;
if($mysqli->affected_rows<1) $results=$mysqli->info;
}
$res->close();
}
$mysqli->close();
return $results;
}
所以如果我打电话:
$MySqlres=connectDB("select * from `modx_events` events limit 1");
var_dump($MySqlres);
我得到了一个很好的关联数组,其中包含我选择的内容。
现在不幸的是,以下 mysql 查询将返回 NULL 作为其所有数组键的值:
$MySqlres=connectDB("select *, events.`id` as `ID`,venues.`name` as `venueName`,
venues.`suburb` as `venueSuburb`,venues.`advertiser` as `venueAdvertiser`
from `modx_events` events left join `modx_venues` venues on events.`venue`=venues.`id`
where events.`id`!='e' order by events.`start_date` asc, venues.`name` limit 1");
(相同的查询作为纯 SQL 运行,并将返回正确的值)知道这可能是什么吗?我的关联数组函数是否失败?我实现查询的方式有问题吗?
ps:PDO不是一个选项,也没有安装mysqlnd ... :(
附加问题
- 仅仅是为了保留关联数组的返回,这是否会产生过多的开销?我应该去
$res->fetch_object()
吗?