0

我正在尝试为我的访问数据库连接创建一个类并返回一个记录集,然后使用 MoveNext() 遍历 RS。

class AccessDBConnection 
{ 
private $db; 
private $sql; 

function __construct($db, $sql) {

    $conn = new COM('ADODB.Connection') or exit('Cannot start ADO.');
    $conn->Open("DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=$db"); 

    $rs = $conn->Execute($sql);
    return $rs;

}

采用:

function testclass () {
    $rs = new AccessDBConnection("e:\database.mdb", "SELECT StudentID, UserName FROM MyTable WHERE StudentID = 'BJxxxx'");

    while (!$rs->EOF) { 
        $SID =  $rs->Fields['StudentID']->Value; 
        $UN =  $rs->Fields['UserName']->Value;
            echo $SID . " -- CLASS TEST -- " . $UN . "<br>";
                $rs->MoveNext(); 
    }
}
4

2 回答 2

3

您不能从构造函数返回结果集。

创建一些分离的方法,比如getRS返回它。

class AccessDBConnection 
{
    private $conn;

    public function __construct($db) {

        $this->conn = new COM('ADODB.Connection') or exit('Cannot start ADO.');
        $this->conn->Open("DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=$db"); 

    }

    public function query($sql) {

        return $this->conn->Execute($sql);

    }

}

用法:

function testclass () {
    $db = new AccessDBConnection("e:\database.mdb");
    $rs = $db->query("SELECT StudentID, UserName FROM MyTable WHERE StudentID = 'BJxxxx'");

    while (!$rs->EOF) { 
        $SID =  $rs->Fields['StudentID']->Value; 
        $UN =  $rs->Fields['UserName']->Value;
            echo $SID . " -- CLASS TEST -- " . $UN . "<br>";
                $rs->MoveNext(); 
    }
}
于 2013-01-08T14:31:25.227 回答
2

构造函数不返回。所以调用:

$rs = new AccessDBConnection($db, $sql);

不会产生记录集。

一些通用指针:

  • 做的很少,__construct以便在您进行测试时更容易
  • 创建一个类似于public function connect()执行连接的方法
  • 创建用于执行查询和返回记录集的方法。

或者找到一个已经完成工作的包装类。重写轮子没有意义。

于 2013-01-08T14:35:55.420 回答