在手册中,每个查询完成后,都会关闭连接。那么当有多个数据库操作的时候这样就导致不停的生成与释放连接,是不是不合理?
比如,有一个a.php,里面有20个函数,分别要实例化20个对象,每个对象中都有数据库操作。
那么,有三种方法:
1.在20个对象的每个类中分别获得一个数据库连接,操作完成并关闭。
2.在a.php中获得数据库连接,在每个函数中,把连接传参进去,最终在a.php释放。
3.生成一个静态的数据库连接对象,每个类中调用ConnectionClass::db
怎么样比较好,请大家讨论讨论。
.
用一个静态变量保存数据库连接就可以实现在一个请求中多个函数只连接一次数据库了.
如果再开启持久连接,就可以实现一个PHP-FPM进程在多次请求中共享一个数据库连接了.
@impig33 下面两次函数调用返回结果都是一样的,可见$db被第一次赋值后,第二次不会再去执行else里的分支,也就不会再生成一个uniqid数.