1. ホーム
  2. php

[解決済み] [Solved] Fatal error: メンバ関数bind_param()のbooleanに対する呼び出し [重複] [重複

2022-01-18 02:08:01

質問

DBから設定を取得する関数をせっせと作っていたら、突然こんなエラーに遭遇しました。

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%意図したとおりに動作していることを確認しています。 DB接続の設定は、設定ファイルで行っています。

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

テーブルは存在し、要求された設定も存在し、DBも存在するのですが、それでも、このエラーは消えません。ここで、DBが正しいことを証明します。

解決方法は?

問題はそこにある。

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

prepare() メソッドは false で、それを確認する必要があります。なぜ false の中に)テーブル名やカラム名が含まれている可能性があります。 SELECT または WHERE

$this->db->conn->error_list