Проблема PDO с битовыми полями [дубликат]

Dec 01 2020

Попытка выполнить вставку в таблицу с битовыми полями, но в результате все поля по умолчанию заполнены как 1. Не понимаю, где моя ошибка или это какая-то конкретная в PDO.

Пример предварительно подготовленного запроса:

INSERT INTO TABLE (is_hidden, is_on_net, is_off_net, is_international)
VALUES (:is_hidden, :is_on_net, :is_off_net, :is_international)

[is_hidden] => 0
[is_on_net] => 1
[is_off_net] => 0
[is_international] => 0


$this->db->preparedQuery($query, $data); public function preparedQuery($query, $params) { try { $this->checkConnection();
        $stmt = $this->pdo->prepare($query); if (!$stmt->execute($params)) { $this->utility->loggerAll($this->logPrefix, __FUNCTION__, $this->logLevel, 1, 'Failed to execute prepared query! ' . $this->pdo->errorInfo()[2] . ', query: ' . $query . ', params: ' . json_encode($params)); return false; } } catch (PDOException $e)
    {
        $this->utility->loggerAll($this->logPrefix, __FUNCTION__, $this->logLevel, 1, 'Failed to execute prepared query! ' . $e->getMessage() . ', query: ' . $query . ', params: ' . json_encode($params));
        
        return false;
    }
    
    return $stmt;
}

Ответы

1 quaresma89 Dec 01 2020 at 21:08

Устранена проблема с изменением поля данных на tinyint, поскольку есть некоторые проблемы с битовыми полями в PDO.

Тот же вопрос: PDOstatement (MySQL): вставка значения 0 в поле bit (1) приводит к 1, записанному в таблице