gpt4 book ai didi

php - 在 CodeIgniter 中使用 this->db->e​​scape_str() 函数时出现语法错误

转载 作者:行者123 更新时间:2023-11-30 22:56:34 27 4
gpt4 key购买 nike

我想通过以下方式将我的输入数据发送到我的 CodeIgniter 应用程序中的 SQL 查询:

  $sdata['department'] = $this->input->post('department'); //Data as text input 
$sql = "SELECT MAX(roll) FROM student WHERE department = ".this->db->escape_str($sdata['department']);

上面的代码在我的 Controller 中。

我不断收到以下错误:

  Parse error: syntax error, unexpected '->' (T_OBJECT_OPERATOR)

这很可能是一个语法错误,但我无法确定是我的代码的哪一部分造成的。

我还浏览了 CodeIgniter 用户指南的查询部分,但那里没有解释清楚。

任何人都可以告诉我我的错误在哪里,以及我正在尝试做的事情的正确语法是什么?

我的 Controller -

   <?php
if ( ! defined('BASEPATH')){ exit('No direct script access allowed');}
class Student extends CI_Controller
{
function __construct()
{
parent::__construct();
#$this->load->helper('url');
$default_roll = '20141000';
$this->load->model('student_model');
$this->load->helper('string');
}

//Show all Students
public function index()
{
$data['student_list'] = $this->student_model->get_all_students();
$this->load->view('student_view', $data);
}


//Insert a student
public function insert_student_db()
{
$sdata['name'] = $this->input->post('name');
$sdata['department'] = $this->input->post('department');

$sql = "SELECT MAX(roll) FROM student WHERE department = ".this->db->escape_str($sdata['department']);
$query = $this->db->query($sql);

$rolltext = substr($query, 9);
$year = substr($query, 3, -3);

if($rolltext == NULL && $year == NULL)
{
$rolltext = str_pad(1,3,'0',STR_PAD_LEFT);
$year = '2014';
}

else
{
$rolltext++;
$rolltext = str_pad($rolltext,3,'0',STR_PAD_LEFT);
if($rolltext == '100')
{
$rolltext = str_pad(1,3,'0',STR_PAD_LEFT);
$year++;
}
}

$sdata['roll'] = $sdata['department'].$year.$rolltext;

$sdata['email'] = $this->input->post('email');
$sdata['mobile'] = $this->input->post('mobile');
$res = $this->student_model->insert_student($sdata);
if($res)
{
header('location:'.base_url()."index.php/student/".$this->index());

}

}
}
?>

最佳答案

[礼貌:用户Ismael Miguel ]

问题出在我的 Controller student.php 中的这一行:

  $sql = "SELECT MAX(roll) FROM student WHERE department = ".this->db->escape_str($sdata['department']);

一个非常愚蠢的错误,在一个非常基本的事情上。 PHP 中的所有变量必须以“$”符号开头。我只是错过了。

因此,在更正该位之后,它看起来像这样:

$sql = "SELECT MAX(roll) FROM student WHERE department = ".$this->db->escape_str($sdata['department']);

现在一切正常。

PHP 无法识别没有“$”符号的this。这就是它抛出解析错误的原因。

关于php - 在 CodeIgniter 中使用 this->db->e​​scape_str() 函数时出现语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26118859/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com