切换到 sqlsrv dbdriver 后在布尔错误上调用成员函数 result()

Call to a member function result() on boolean error after switching to sqlsrv dbdriver

除了从我的模型触发存储过程并开始在布尔错误行上显示对成员函数 result() 的调用外,一切正常。

这里是一个代码示例,没有使用 SP,它工作正常。

function get_myeligible_info($id)
{
    $sql = "SELECT * FROM emp_list_manila where employee_empid = '".$id."'";
    $query = $this->db->query($sql);
    return $query->result();
}

这里是显示错误的确切代码。

function get_for_batch_insert2()
{

$query = $this->db->query("[INSERT_TTUMBATCH]");
return $query->result(); //ERROR HERE

}

Web 应用程序框架:Codeigniter 3 数据库:MS SQL

首先,永远不要将变量直接放入查询中。始终像这样使用 parameter binding

function get_myeligible_info($id)
{
    $sql = "SELECT * FROM emp_list_manila WHERE employee_empid = ?";
    $query = $this->db->query($sql, [$id]);
    return $query->result();
}

对于存储过程,不能只按名称调用它们,you have to use EXEC:

function get_for_batch_insert2()
{
    $query = $this->db->query("EXEC INSERT_TTUMBATCH");
    return $query->result();
}

对于这两个调用,您应该检查错误并适当地处理它们:

function get_for_batch_insert2()
{
    $query = $this->db->query("EXEC INSERT_TTUMBATCH");
    if ($query) {
        return $query->result();
    } else {
        return false;
    }
}