gpt4 book ai didi

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

转载 作者:IT老高 更新时间:2023-10-28 12:03:37 25 4
gpt4 key购买 nike

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

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/27394710/

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