Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/85.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_Html_Sql_Database - Fatal编程技术网

Php 在用户添加主题时向数据库添加点

Php 在用户添加主题时向数据库添加点,php,html,sql,database,Php,Html,Sql,Database,用户可以通过填写表单来添加主题 我想要什么: 在我的数据库中输入行“punten(points)”以更新分数。如果分数是10。加起来还有10分 我的功能: public function update_points($tabel, $query){ $q = ''; foreach ($query as $key => $value) { $value = str_replace("'","'",$value); $q .=

用户可以通过填写表单来添加主题

我想要什么: 在我的数据库中输入行“punten(points)”以更新分数。如果分数是10。加起来还有10分

我的功能:

public function update_points($tabel, $query){
    $q = '';
    foreach ($query as $key => $value) {
        $value  = str_replace("'","'",$value);
        $q .= "`".$key."` = '".$value."',";
    }

    if(isset($q) && ($q !='')) {
        $q = substr($q,0,-1);
        $this->database->query("UPDATE ".$tabel." SET punten = punten + ".$q." LIMIT 1");
        $this->database->execute();
    }   
}
if(isset($_POST['react_btn'])){                              
$query['punten'] = 10;
$app->update_points('klanten', $_SESSION['klant_id'], $query);
Html文件:

public function update_points($tabel, $query){
    $q = '';
    foreach ($query as $key => $value) {
        $value  = str_replace("'","'",$value);
        $q .= "`".$key."` = '".$value."',";
    }

    if(isset($q) && ($q !='')) {
        $q = substr($q,0,-1);
        $this->database->query("UPDATE ".$tabel." SET punten = punten + ".$q." LIMIT 1");
        $this->database->execute();
    }   
}
if(isset($_POST['react_btn'])){                              
$query['punten'] = 10;
$app->update_points('klanten', $_SESSION['klant_id'], $query);

您实际上得到了一个MySQL错误。如果使用的是
UPDATE
,则不能使用
LIMIT
。我建议改用
WHERE id=?
,除非您不介意更新所有行。这取决于您使用哪个库与数据库对话
->query
进入一个
->execute
将失败,因为
->query
实际上已经执行,因此,
$this->database->execute()没有任何功能运行。我认为您使用的是<代码> MySqLI>代码>因为PDO没有<代码>执行< /代码>它有<代码> Exc> <代码>无论如何,您应该考虑使用该方法在<代码> $q>代码>(不在您的$TabEL中,因为您不能准备一个表名/列名),最后,每一个优秀的程序员都应该利用错误报告来帮助缩小问题的范围。同样,如果你在使用MySQLi,那么就去输出错误->Lol final point sorry=)顺便看看你的方法,我想你可能遗漏了什么:
update_points($tabel,$query){
$app->update_points('klanten',$u SESSION['klant_id',$query);