php - 在从数据库获取设置的函数上我遇到了错误

标签 php mysqli

我正忙于一个从数据库获取设置的函数,突然,我遇到了这个错误:

Fatal error: Call to a member function bind_param() on boolean in C:\xampp2\htdocs\application\classes\class.functions.php on line 16

通常,这意味着我从不存在的表和内容中选择内容。但在这种情况下,我不是...

这是 getSetting功能:

public function getSetting($setting)
{
    $query = $this->db->conn->prepare('SELECT value, param FROM ws_settings WHERE name = ?');
    $query->bind_param('s', $setting);
    $query->execute();
    $query->bind_result($value, $param);
    $query->store_result();
    if ($query->num_rows() > 0)
    {
        while ($query->fetch()) 
        {
            return $value;
            if ($param === '1')
            {
                $this->tpl->createParameter($setting, $value);
            }
        }
    }
    else
    {
        __('invalid.setting.request', $setting);
    }
}

$this->db变量通过构造函数传递。如果需要的话,这里是:

public function __construct($db, $data, $tpl)
{
    $this->db = $db;
    $this->tpl = $tpl;
    $this->data = $data;
    $this->data->setData('global', 'theme', $this->getSetting('theme'));
}

此外,由于我正在使用数据库,因此我的数据库连接:

class Database
{
    private $data;

    public function __construct($data)
    {
    $this->data = $data;
    $this->conn = new MySQLi(
      $this->data->getData('database', 'hostname'), 
      $this->data->getData('database', 'username'), 
      $this->data->getData('database', 'password'), 
      $this->data->getData('database', 'database')
    );
    if ($this->conn->errno)
    {
        __('failed.db.connection', $this->conn->errno);
    }
    date_default_timezone_set('Europe/Amsterdam');
}

我已经测试了连接,100% 肯定它按预期工作。 我正在配置文件中设置数据库连接:

'database' => array(
    'hostname' => '127.0.0.1',
    'username' => 'root',
    'password' => ******,
    'database' => 'wscript'
)

现在奇怪的是;表存在,请求的设置存在,数据库存在,但是该错误仍然不会消失。以下是数据库正确性的一些证据:

IMG

最佳答案

问题在于:

$query = $this->db->conn->prepare('SELECT value, param FROM ws_settings WHERE name = ?');
$query->bind_param('s', $setting);

prepare()方法可能返回 false,您应该检查这一点。至于为什么返回false,可能是表名或列名(在SELECTWHERE子句中)不正确?

此外,请考虑使用类似 $this->db->conn->error_list 的内容检查解析 SQL 时发生的错误。 (我偶尔也会回显实际的 SQL 语句字符串并粘贴到 phpMyAdmin 中进行测试,但肯定存在一些问题。)

关于php - 在从数据库获取设置的函数上我遇到了错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46630698/

相关文章:

php - Webmatrix 用户 '' @'localhost' 访问被拒绝(使用密码 : NO)

php - Laravel:按名称从路由获取 URL

php - 在 Sylius/Symfony 中解析 Controller 服务

php - PayPal REST API 支付收款人

php - 删除 PHP 数组中的空值

php - 显示 2 位小数而不四舍五入

php - mysqli_real_escape_string 使用什么类型的引号?

php - 在内部连接语句上尝试 ->num_rows 时出现“尝试获取非对象的属性”错误

php - 跟踪页面浏览量并存储在 MySQL 中的最佳方式

php - 如果第一个查询已插入其数据,我想插入第二个查询的数据