0

Access データベース接続用のクラスを作成してレコードセットを返し、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 に答える