PHP类中的范围

时间:2009-02-02 20:46:19

标签: php database connection scope

我正在创建一个数据库连接对象,我不确定最好的方法是什么......

如果我创建了一个建立连接的dbConnection类(使用mysql_connect),那么我可以从主脚本的任何地方调用mysql_query吗?

来自OTHER课程内部怎么样?我是否需要将对象或属性作为参数传递?

基本上,我正在寻找使用简单类连接到数据库ONCE的最佳方式(在速度+内存方面)......

我已经发布了数据库连接类的构造函数:

function __construct($database="") {
if (!empty($database)){ $this->db = $database; }
$this->dblink = mysql_connect($this->host,$this->username,$this->password);
if (!this->dblink) {
    //Fatal Error
}
mysql_select_db($this->db, $this->dblink);

}

3 个答案:

答案 0 :(得分:1)

我建议尝试ezSQL,而不是创建自己的数据库抽象类。作者非常出色地使其易于使用。从类完成的查询返回的数据结构比mysql_query返回的数据结构更灵活,它可以为您节省大量的工作。

答案 1 :(得分:1)

你快到了。我的数据库类是这样的:

class DB {
  function __construct($host,$user,$pass,$db) {
    // error checking has been removed for brevity
    $this->mysql = mysql_connect($host,$user,$pass);
    mysql_select_db($this->mysql, $db);
  }
  function fetchRows($query) {
    // error checking removed again
    $result = mysql_query($this->mysql);
    $return = array();
    while($data = mysql_fetch_assoc($result))
      $return[] = $data;
    mysql_free_result($result);
    return $return;
  }
}

在我的主要包含文件中,我有类似的东西:

require 'DB.inc.php';
$GLOBALS['DB'] = new DB('localhost', 'root', '', 'my_database');

然后在我的项目的任何部分,我都可以运行这样的查询:

global $DB;
$query = 'SELECT UserID, UserName FROM users';
foreach($DB->fetchRows($query) as $user)
    echo "$user[UserID]: $user[UserName]\n";

注意:建议不要使用mysql_pconnect(),出于某些原因,请参阅manual page用户评论。

答案 2 :(得分:0)

如果要执行查询,则应将连接对象作为参数传递给查询函数。您需要在任何想要运行查询的地方访问连接对象。

require_once DBConnection;
require_once SomeClass;

$con = new DBConnection();
$query = "Select * FROM Users";
mysql_query($query, $con->link);

// Use the connection in another class that takes a connection object in the constructor
$someclass = new SomeClass($con);
$someclass->executeQueryThree();

但是,我更倾向于在DBConnection类中使用mysql_query作为这样的方法:

公共函数查询($ query){         $ result = mysql_query($ query,$ this-> link);         返回$ result;    }

然后执行以下操作:

$query = "Select * FROM Users";
$con = new DBConnection();
$result = $con->query($query);

// From within SomeClass
$someclass = new SomeClass();
$result = $con->query($someclass->getQuery3());