如何使用PDO将二进制数据插入MSSQL

Ric*_*ard 12 php sql sql-server pdo

我目前遇到了一个奇怪的错误.

设置:带有localdb的MSSQL Server 2012 Express目标表排序规则是:SQL_Latin1_General_CP1_CI_AS

带有MCRYPT_RIJNDAEL_256和MCRYPT_MODE_ECB的Zend Server 5.6 MCrypt上的PHP 5.3.9

Sublime Text 2默认编码(我读的是UTF8 BOM)

我正在使用PDO与MSSQL服务器的官方MS适配器.除了一件事之外,一切都很好:由于密码,我无法在管理员表中写入一行.

让我们看看我的ENCRYPTED密码:

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

这是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
Run Code Online (Sandbox Code Playgroud)

当我使用我的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)"
Run Code Online (Sandbox Code Playgroud)

我使用预准备语句和bindParam没有额外选项的函数来执行我的SQL语句.

如果有人有想法,如何解决,请告诉我.感谢Anykind的帮助!

And*_*aal 2

您应该将排序规则更改为类似utf8_unicode_ci处理那些少数无人看管的字符的排序规则。

你也应该尝试这样的事情:

$db = new PDO('foo', 'bar', 'blo');
$stmt = $db->prepare("select foo, bar from table where id=?");
$stmt->execute(array($_GET['id']));
$stmt->bindColumn(1, $type, PDO::PARAM_STR, 256);
$stmt->bindColumn(2, $lob, PDO::PARAM_LOB);
$stmt->fetch(PDO::FETCH_BOUND);
header("Content-Type: $type");
fpassthru($lob);
Run Code Online (Sandbox Code Playgroud)

要仔细检查类型(这是错误/错误开始发生的地方),请执行此检查,甚至可能代替上面示例的最后一行:

if (is_string($lob)) echo $lob;
else fpassthru($lob);
Run Code Online (Sandbox Code Playgroud)