我正在创建一个数据库连接对象,我不确定最好的方法是什么......
如果我创建了一个建立连接的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);
}
答案 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());