我在 mysql-connect 页面上找到了 php.net 上的数据库适配器。
这是一个浏览量很大的页面(我会想象)。
它包括作者声称的单例模式类。
在 http://php.net/manual/en/function.mysql-connect.php 上找到
作家 说:
"这是一个用于管理单个数据库连接的单例类。 这 Open 方法使用常量值作为 defautls,从 ini 文件中读取 通过加载在每个网页顶部的初始值设定项脚本。 你 还可以通过手动输入自己的默认值来覆盖默认值(在 如果您需要在脚本中切换服务器或数据库名称)。炊子 函数接受预准备语句并将返回第一行, 第一个关联行、第一个单元格或整个结果集基于 第二个参数(如果省略整个结果)。
用法: $DB = DB::Open();
$result = $DB->qry(" {SQL 语句} ;");
<?php
abstract class Database_Object
{
protected static $DB_Name;
protected static $DB_Open;
protected static $DB_Conn;
protected function __construct($database, $hostname, $hostport, $username, $password)
{
self::$DB_Name = $database;
self::$DB_Conn = mysql_connect($hostname . ":" . $hostport, $username, $password);
if (!self::$DB_Conn) { die('Critical Stop Error: Database Error<br />' . mysql_error()); }
mysql_select_db(self::$DB_Name, self::$DB_Conn);
}
private function __clone() {}
public function __destruct()
{
// mysql_close(self::$DB_Conn); <-- commented out due to current shared-link close 'feature'. If left in, causes a warning that this is not a valid link resource.
}
}
final class DB extends Database_Object
{
public static function Open($database = DB_NAME, $hostname = DB_HOST, $hostport = DB_PORT, $username = DB_USER,$password = DB_PASS)
{
if (!self::$DB_Open)
{
self::$DB_Open = new self($database, $hostname, $hostport, $username, $password);
}
else
{
self::$DB_Open = null;
self::$DB_Open = new self($database, $hostname, $hostport, $username, $password);
}
return self::$DB_Open;
}
public function qry($sql, $return_format = 0)
{
$query = mysql_query($sql, self::$DB_Conn) OR die(mysql_error());
switch ($return_format)
{
case 1:
$query = mysql_fetch_row($query);
return $query;
break;
case 2:
$query = mysql_fetch_array($query);
return $query;
break;
case 3:
$query = mysql_fetch_row($query);
$query = $query[0];
return $query;
default:
return $query;
}
}
}
?>
看完代码后,我有一个问题,这真的是一个单例(参见数据库类和打开函数)吗?
静态属性如何使单例模式工作?
我明白你的意思,如果self::$DB_Open
确实存在,它会将其设置为 null 并无论如何都会创建该对象的新实例。
看来你是对的,这似乎不像单例模式。
关于具有静态属性的单例模式。与对象作用域中的实例变量不同,静态变量位于类作用域中。
这意味着即使您多次创建对象,它仍然每次都对静态属性使用相同的值。这就是使它们非常适合计数器并因此适用于全球单例的原因。
请参阅以下内容:
Class A {
static int y=1;
int x=3;
}
$newA = new A();
$newB = new A();
$newC = new A();
上面创建了 x 的 3 个实例。您可以在 1 个实例中进行更改,并且只会在该 1 个实例中进行更改。
但只创建了 y 的 1 个实例。因此,1 和所有 3 的变化都会改变。它们都存在于相同的上下文中。因此指向相同的值。如果您递增一个,其他将显示相同的递增等。
因此,重申一下,即使只有DB_Conn
的单个实例存在,它也会不断重置它并再次写入它(它不必像这样操作)。
为了解决这个问题,作者可以返回 self::$DB_Open
属性(如果它确实存在)。