Как вставить двоичные данные в MSSQL с помощью PDO

В настоящее время я испытываю странную ошибку.

Установка :MSSQL Server 2012 Express с локальной БД Сопоставление целевой таблицы: :SQL _Latin1 _General _CP1 _CI _AS

PHP 5.3.9 на Zend Server 5.6 MCrypt с MCRYPT _RIJNDAEL _256 и MCRYPT _MODE _ECB

Кодировка Sublime Text 2 по умолчанию (Я читал, что это UTF8 BOM)

Я использую PDO с официальным адаптером MS для сервера MSSQL. Все работает отлично, кроме одного :Я не могу записать строку в свою таблицу администратора из-за пароля.

Давайте посмотрим на мой ЗАШИФРОВАННЫЙ пароль:

y"ûƒ^äjw¾bðúl5êù-Ö=W¿Š±¬GP¥Œy÷&ø

Это трассировка PDO:

Array
(
    [0] => IMSSP
    [1] => -7
    [2] => An error occurred translating string for input param 3 to UCS-2: No mapping for the Unicode character exists in the target multi-byte code page.


)
SQL: [120] INSERT INTO administrator ( [username], [email], [password], [section] )  VALUES(:username, :email, :password, :section)
Params:  4
Key: Name: [9] :username
paramno=0
name=[9] ":username"
is_param=1
param_type=2
Key: Name: [6] :email
paramno=1
name=[6] ":email"
is_param=1
param_type=2
Key: Name: [9] :password
paramno=2
name=[9] ":password"
is_param=1
param_type=2
Key: Name: [8] :section
paramno=3
name=[8] ":section"
is_param=1
param_type=2

Когда я использую свой Центр управления MSSQL, я могу вставить свою строку с точно таким же запросом SQL. Полагаю, установка колонки в порядке:

    ["id"]=>
    string(3) "int"
    ["username"]=>
    string(12) "nvarchar(45)"
    ["email"]=>
    string(12) "nvarchar(45)"
    ["password"]=>
    string(12) "varbinary(45)"
    ["section"]=>
    string(11) "nvarchar(7)"
    ["country_code"]=>
    string(11) "nvarchar(2)"

Я использую подготовленные операторы и функцию bindParamбез дополнительных опций для выполнения моих операторов SQL.

Если у кого-то есть идея, как это решить, пожалуйста, дайте мне знать. Любая помощь приветствуется!

12
задан Richard 29 June 2012 в 14:41
поделиться