我有一个从数据库加载事物列表并将它们放入选择列表的函数。函数如下:(伪代码)
protected function Foo()
{
try {
get pdo instance
prepare statement
if (pdo query executes)
{
while (row = fetched rows)
{
do stuff with row
}
}
}
catch (PDOException $ex)
{
do error stuff here
}
}
NetBeans 给出了一个代码提示,它有太多的行和太多的嵌套块。个人觉得功能应该可以接受。我也觉得将逻辑分解成更小的函数有点疯狂,但为什么 netbeans 会骗我:)?
所以我的问题如下:
这是错误的逻辑还是我可以继续前进?我欢迎任何关于如何重新设计函数以适应 NetBean 约束的建议。
编辑:
我不会回答我自己的问题,但在这种情况下,有一个不需要的嵌套块。pdo 是从具有 try/catch 块的单例类中检索的。我不需要在这个函数中再次重复它,因为异常已经被捕获了。
编辑2:
删除 try catch 块就像抢彼得付钱给保罗一样。因此,如果在创建 pdo 实例时抛出异常,它不会停止执行。因此,我们尝试在未正确初始化的 PDO 对象上调用 prepare 语句。这迫使我们在准备调用之前进行另一个测试,因此只是返回到原始函数的返工。
以我的经验,这意味着我的逻辑在某个地方被打破了。如果我有什么值得说的,我将回顾我的设计并回击。
再次感谢大家