duanguochong0397 2012-05-14 13:27
浏览 124
已采纳

PHP - 如何在函数中使用SWITCH

I am trying to cut down on the amount of select statements, updates etc in my code so I thought that I would try to create a function for this, however I am puzzled that my efforts are failing at the first hurdle.

I have Googled this issue quite comprehensively (I feel) and I can't find any differences in the examples that I have found.

This is my function complete with print statements to help me diagnose the issue.

function select_statement($action, $table, $where){
print $action.' - ';

switch ($action){
    case 'select':
        print 'select used - ';
        $thequery = 'SELECT * FROM '. $table . ' WHERE '. $where;
    case 'insert':
        print 'insert used - ';
        $thequery = 'INSERT INTO '. $table;
    case 'update':
        print 'update used - ';
        $thequery = 'UPDATE ' . $table . ' SET ';
    }
print $thequery;
mysql_query($thequery);

}

This is the line that calls the function:-

$logins = select_statement('select', 'users', 'user_id=1');//calls function

This is the result:-

select - select used - insert used - update used - UPDATE users SET 

As you can see the code is triggering each of the print statements and seemingly ignoring the 'case' statements.

I'm really not sure what it is that I am doing wrong here?

  • 写回答

1条回答 默认 最新

  • dongzhanlu0658 2012-05-14 13:28
    关注

    You forgot to use break. Without it each case statement will "fall through" to the next one and continue operating. break stops execution at the end of each case statement`;

    switch ($action){
        case 'select':
            print 'select used - ';
            $thequery = 'SELECT * FROM '. $table . ' WHERE '. $where;
            break;
        case 'insert':
            print 'insert used - ';
            $thequery = 'INSERT INTO '. $table;
            break;
        case 'update':
            print 'update used - ';
            $thequery = 'UPDATE ' . $table . ' SET ';
            break;
        }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?