Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/283.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP-如何在函数中使用开关_Php_Function_Switch Statement - Fatal编程技术网

PHP-如何在函数中使用开关

PHP-如何在函数中使用开关,php,function,switch-statement,Php,Function,Switch Statement,我试图减少代码中select语句、更新等的数量,所以我想我会尝试为此创建一个函数,但是我感到困惑的是,我的努力在第一个障碍上失败了 我在谷歌上搜索过这个问题(我觉得),在我找到的例子中我找不到任何不同之处 这是我的函数,包含帮助我诊断问题的打印语句 function select_statement($action, $table, $where){ print $action.' - '; switch ($action){ case 'select': print

我试图减少代码中select语句、更新等的数量,所以我想我会尝试为此创建一个函数,但是我感到困惑的是,我的努力在第一个障碍上失败了

我在谷歌上搜索过这个问题(我觉得),在我找到的例子中我找不到任何不同之处

这是我的函数,包含帮助我诊断问题的打印语句

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);

}
这是调用函数的行:-

$logins = select_statement('select', 'users', 'user_id=1');//calls function
结果是:-

select - select used - insert used - update used - UPDATE users SET 
正如您所看到的,代码正在触发每个print语句,并且似乎忽略了“case”语句


我真的不确定我到底做错了什么?

你忘了使用
break
。没有它,每个案例陈述都会“跌破”到下一个案例陈述并继续运行
break
在每个
case
语句的末尾停止执行

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;
    }

这就是我喜欢堆栈溢出的原因——当你看不见树木的时候谢谢约翰:)