Я пытаюсь вставить некоторые данные в таблицу базы данных, но я получаю это исключение, когда пытаюсь сохранить символ евро в столбце валюты :Невозможно вставить символы MySQL в MySQL, используя PHP/PDO
PDOException: SQLSTATE[HY000]: General error: 1366
Incorrect string value: '\x80' for column 'currency' at row 1
Если я не использую какие-либо символы, он работает нормально. Никакое исключение не выбрасывается, и данные записываются правильно в таблице базы данных.
Это стек технологии я использую:
- PHP 5.6.16
- MySQL 5,7
- Apache 2,4
- PDO (вместо MySQLi)
У меня есть попытался найти решение Google, но для меня ничего не работало:
- Я попытался изменить набор символов из моих баз данных, таблиц и столбцов UTF8mb4
- Я сделал изменения конфигурации наборов символов в моей php.ini
- Я попробовал его с MySQLi и maysql вместо PDO
- Я написал «кодировки = utf8mb4» в строке подключения объекта PDO
Но ничего не было полезно ...
Это создать сценарий моего стола, я использую в данный момент:
CREATE TABLE `cars` (
`car_id` int(11) NOT NULL AUTO_INCREMENT,
`brand` varchar(191) COLLATE utf8mb4_unicode_ci NOT NULL,
`model` varchar(191) COLLATE utf8mb4_unicode_ci NOT NULL,
`car_trim` varchar(191) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`model_year` int(11) DEFAULT NULL,
`car_condition` varchar(191) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`car_type` varchar(191) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`currency` varchar(191) COLLATE utf8mb4_unicode_ci DEFAULT NULL, <-- Where the € should be
PRIMARY KEY (`xy`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4
COLLATE=utf8mb4_unicode_ci;
Мое соединение PDO выглядит следующим образом:
if(!isset(self::$connection)) {
try {
self::$connection = new PDO('mysql:host='.self::$config['host'].
';dbname='.self::$config['dbname'].
';port='.self::$config['port'].
';charset='.self::$config['charset'], //utf8mb4
self::$config['username'],
self::$config['password']
);
self::$connection->setAttribute(PDO::ATTR_ERRMODE,
PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
self::$logger->LogError('Connection.php: ' . $e->getMessage());
echo $e->getMessage();
self::$connection->rollBack();
$this->closeConnection();
}
}
РНР код с оператора вставки:
$db = new Db();
$car = new Car($_POST['carBrand'], $_POST['carModel'], $_POST['carTrim'],
$_POST['carModelYear'], $_POST['carCondition'],
$_POST['carType'], $_POST['carFuelType'], $_POST['carTransmission'],
$_POST['carEngine'], $_POST['carCylinder'],
$_POST['carMileage'], $_POST['carExteriorColor'],
$_POST['carInteriorColor'], $_POST['carLocation'], $_POST['carVin'],
$_POST['carDriveTrain'], $_POST['carStock'], $_POST['carPrice'],
$_POST['carPriceDetails'], $_POST['carCurrency'],
$_POST['carTax'], $_POST['carTaxDetails'], $_POST['carDescr'],
$_POST['carBodyDescr'], $_POST['carDriveTrainDescr'],
$_POST['carExteriorDescr'], $_POST['carElectronicsDescr'],
$_POST['carSaftyFeaturesDescr'], $_POST['carSpecialFeaturesDescr'],
null, null, null, null, null, null, null, null, null, null, 'Edi', 'Edi',
(empty($_POST['carOnline'])) ? 'off' : 'on');
$car_insertStm = 'INSERT INTO cardealer.cars (' .
'brand, model,car_trim,model_year,car_condition,car_type, fuel_type, transmission, ' .
'car_engine, cylinder, mileage, exterior_color, interior_color, location, vin, drive_train, ' .
'stock, price, price_descr, currency, tax, tax_descr, car_descr_long, body_descr, ' .
drive_train_descr, exterior_descr, electronics_descr, safty_features_descr, special_features_descr, car_pic_1, car_pic_2, car_pic_3, ' .
'car_pic_4, car_pic_5, car_pic_6, car_pic_7, car_pic_8, car_pic_9, car_pic_10, create_user, ' .
'change_user, car_online) ' .
'VALUES (:brand, :model, :car_trim, :model_year, :car_condition, :car_type, :fuel_type, :transmission, :car_engine, :cylinder, ' .
':mileage, :exterior_color, :interior_color, :location, :vin, :drive_train,
:stock, :price, :price_descr, :currency, :tax, :tax_descr, ' .
':car_descr_long, :body_descr, :drive_train_descr, :exterior_descr,
:electronics_descr, :safty_features_descr, :special_features_descr, ' .
':car_pic_1, :car_pic_2, :car_pic_3, :car_pic_4, :car_pic_5, :car_pic_6,
:car_pic_7, :car_pic_8, :car_pic_9, :car_pic_10, :create_user, ' .
':change_user, :online) ';
$pStatement = $db->getConnection()->prepare($car_insertStm);
$pStatement->bindParam(':brand', $_POST['carBrand'], PDO::PARAM_STR);
$pStatement->bindParam(':model', $_POST['carModel'], PDO::PARAM_STR);
$pStatement->bindParam(':car_trim', $_POST['carTrim'], PDO::PARAM_STR);
$pStatement->bindParam(':model_year',
$_POST['carModelYear'],PDO::PARAM_INT);
$pStatement->bindParam(':car_condition',
$_POST['carCondition'], PDO::PARAM_STR);
$pStatement->bindParam(':car_type', $_POST['carType'], PDO::PARAM_STR);
$pStatement->bindParam(':fuel_type', $_POST['carFuelType'], PDO::PARAM_STR);
$pStatement->bindParam(':transmission',
$_POST['carTransmission'], PDO::PARAM_STR);
$pStatement->bindParam(':car_engine', $_POST['carEngine'], PDO::PARAM_STR);
$pStatement->bindParam(':cylinder', $_POST['carCylinder'], PDO::PARAM_STR);
$pStatement->bindParam(':mileage', $_POST['carMileage'],PDO::PARAM_INT);
$pStatement->bindParam(':exterior_color',
$_POST['carExteriorColor'], PDO::PARAM_STR);
$pStatement->bindParam(':interior_color',
$_POST['carInteriorColor'], PDO::PARAM_STR);
$pStatement->bindParam(':location', $_POST['carLocation'], PDO::PARAM_STR);
$pStatement->bindParam(':vin', $_POST['carVin'], PDO::PARAM_STR);
$pStatement->bindParam(':drive_train',
$_POST['carDriveTrain'], PDO::PARAM_STR);
$pStatement->bindParam(':stock', $_POST['carStock'], PDO::PARAM_STR);
$pStatement->bindParam(':price', $_POST['carPrice'], PDO::PARAM_STR);
$pStatement->bindParam(':price_descr',
$_POST['carPriceDetails'], PDO::PARAM_STR);
$pStatement->bindParam(':currency', $_POST['carCurrency'], PDO::PARAM_STR); // Parameter binding for the currency --> €
$pStatement->bindParam(':tax', $_POST['carTax'],PDO::PARAM_INT);
$pStatement->bindParam(':tax_descr',
$_POST['carTaxDetails'], PDO::PARAM_STR);
$pStatement->bindParam(':car_descr_long',
$_POST['carDescr'], PDO::PARAM_STR);
$pStatement->bindParam(':body_descr',
$_POST['carBodyDescr'], PDO::PARAM_STR);
$pStatement->bindParam(':drive_train_descr',
$_POST['carDriveTrainDescr'], PDO::PARAM_STR);
$pStatement->bindParam(':exterior_descr',
$_POST['carExteriorDescr'], PDO::PARAM_STR);
$pStatement->bindParam(':electronics_descr',
$_POST['carElectronicsDescr'], PDO::PARAM_STR);
$pStatement->bindParam(':safty_features_descr',
$_POST['carSaftyFeaturesDescr'], PDO::PARAM_STR);
$pStatement->bindParam(':special_features_descr',
$_POST['carSpecialFeaturesDescr'], PDO::PARAM_STR);
$pStatement->bindValue(':car_pic_1', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_2', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_3', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_4', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_5', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_6', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_7', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_8', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_9', null, PDO::PARAM_LOB);
$pStatement->bindValue(':car_pic_10', null, PDO::PARAM_LOB);
$pStatement->bindValue(':create_user', "Edi", PDO::PARAM_STR);
$pStatement->bindValue(':change_user', "Edi", PDO::PARAM_STR);
$pStatement->bindValue(':online',
(empty($_POST['carOnline'])) ? "off" : "on",
PDO::PARAM_STR);
$result = $pStatement->execute();
Было бы очень хорошо, если бы кто-то может помочь мне из этого тез. Всякая помощь высоко оценивается.
Заранее спасибо.
Возможно, мне не хватает этого, потому что я не слишком хорошо знаком с PDO, но где код, который пытается вставить символ евро? В какой колонке это происходит?Вы предоставили определение таблицы для таблицы «cars», в которой нет ничего, что, казалось бы, предназначено для хранения символа евро, поэтому я думаю, вам нужно предоставить больше кода. – dman2306
Спасибо, что прочитали мой вопрос. Я добавил еще несколько кодов. Надеюсь, это поможет вам. – F4k3d
'\ x80', конечно, не является кодовым кодом Unicode, а не UTF-8. Я предполагаю, что ваш исходный код и с ним ваши строки не UTF-8. Тем не менее, мы используем 'utf8_unicode_ci' без проблем с символами вне диапазона ASCII. –