php pdo try,PDO try-catch在函数中的用法

我正在考虑在以后的所有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的新手(还有很多东西要学习),所以(到目前为止),我真的看不到任何缺点或可以改进的地方。

很抱歉,如果不清楚或时间太长。提前致谢。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值