我在PHP编程方面有很多经验,对于我正在制作的一个小方案项目,我想从数据库中获取一些信息
我创建了自己的sql处理程序,使用单例,因此连接不会溢出。
这是我的查询功能:
<?php
public static function query($q){
$a = '';
$b = '';
self::$queries[] = $q;
if(strpos($q, 'INSERT') !== false){
if(!mysql_query($q)){
self::$err[] = mysql_error()."<br />Query: ".$q;
return false;
}
return true;
} elseif(strpos($q, 'SELECT') !== false){
echo $q;
if(!$res = mysql_query($q)){
self::$err[] = mysql_error()."<br />Query: ".$q;
return false;
} else {
if(mysql_num_rows($res) > 1){
while($r = mysql_fetch_assoc($res)){
foreach($r as $key => $val){
self::$results[$r['id']][$key] = $val;
}
}
return self::$results;
} else {
$res = mysql_fetch_assoc($res);
foreach($res as $key => $val){
self::$results[$res['id']][$key] = $val;
}
return self::$results;
}
}
} elseif(strpos($q, 'UPDATE') !== false){
if(!mysql_query($q)){
self::$err[] = mysql_error()."<br />Query: ".$q;
return false;
}
return true;
} elseif(strpos($q, 'DELETE') !== false){
if(!mysql_query($q)){
self::$err[] = mysql_error()."<br />Query: ".$q;
return false;
}
return true;
}
}
?>
现在我想从我创建的表中获取一些数据(表包含2个外键) 表:
CREATE TABLE IF NOT EXISTS `loc_npc` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`loc_id` int(11) NOT NULL,
`npc_id` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `loc_id` (`loc_id`),
KEY `npc_id` (`npc_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ;
ALTER TABLE `loc_npc`
ADD CONSTRAINT `loc_npc_ibfk_2` FOREIGN KEY (`npc_id`) REFERENCES `npcs` (`id`),
ADD CONSTRAINT `loc_npc_ibfk_1` FOREIGN KEY (`loc_id`) REFERENCES `locations` (`id`);
运行此查询时的问题SELECT id, loc_id, npc_id FROM loc_npc WHERE loc_id = 9
它是否以某种方式从另一个表中返回数据,以及正确的数据。
查询在另一个处理程序中运行:
public function getLocationNpc($id){
//return $this->sql->query("SELECT e.`name`, e.`desc`, e.`id` FROM npcs e LEFT JOIN(loc_npc i CROSS JOIN locations l) ON (e.id = i.npc_id AND i.loc_id = l.id) WHERE i.loc_id = $id");
$npcH = new npcHandler();
$npcId = $this->sql->query("SELECT id, loc_id, npc_id FROM loc_npc WHERE loc_id = $id");
echo '<pre>'.print_r($npcId, true).'</pre>';
foreach($npcId as $nId){
$npcArr[] = $npcH->getNpc($nId['npc_id']);
}
return $npcArr;
}
我在phpmyadmin中测试了查询,它只返回正确的数据,与通过我的处理程序执行的查询不同。
我很确定这是一个小而愚蠢的东西,但我似乎无法找到它。
答案 0 :(得分:0)
您似乎没有在任何地方清除self::$results
的内容 - 您是否从之前运行的查询中获得了结果?