我正在考虑在以后的所有Web应用程序中使用PDO。当前(使用到目前为止我从中学到的知识),我站点中用于处理数据库连接的内容是一个Singleton类,如下所示:
class DB {
private static $instance = NULL;
private static $dsn = "mysql:host=localhost;dbname=mydatabase;";
private static $db_user = 'root';
private static $db_pass = '0O0ooIl1';
private function __construct()
{
}
private function __clone()
{
}
public static function getInstance() {
if (!self::$instance)
{
self::$instance = new PDO(self::$dsn, self::$db_user, self::$db_pass);
self::$instance-> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}
return self::$instance;
}
}
另一个文件(functions.php)具有特定于内容的功能,看起来像这样:
function get_recent_activities ()
{
try
{
$db = DB::getInstance();
// --prepare and execute query here, fetch the result--
return $my_list_of_recent_activities;
}
catch (PDOException $e)
{
return "some fail-messages";
}
}
...
这意味着我必须重复try .. catch所有功能。
我的问题是:
我应该如何提高效率?(例如,不必try..catch在所有功能中都重复执行,但仍然能够在每个功能上返回不同的“失败消息”)
这已经是一个好习惯了吗?我仍然是PDO和OOP的新手(还有很多东西要学习),所以(到目前为止),我真的看不到任何缺点或可以改进的地方。
很抱歉,如果不清楚或时间太长。提前致谢。