使用Doctrine存储blob值时出现问题

时间:2010-02-17 14:19:54

标签: php sql-server doctrine blob

我使用Doctrine 1.1.2作为我的ORM框架与Zend Framework和MSSQL服务器后端结合使用。我想要做的是将blob存储到数据库中,但是当我尝试时,Doctrine会给我带来错误。数据库中的列的类型为varbinary(max),Doctrine中的模型配置如下:

$this->hasColumn('binary_data', 'blob', null, array(
         'type' => 'blob',
         'notnull' => false,
         'primary' => false,
         'autoincrement' => false,
         ));

这是使用Doctrine :: generateModelsFromDB生成的,应该是正确的。 blob的来源是文件上传。我已经验证文件上传成功,并且我能够打印二进制数据(显示为一堆乱码数据)。

当我尝试使用Doctrine模型保存二进制数据时,根据我的操作得到不同的错误消息。到目前为止我已经尝试了这个(可能还有一些我不记得了):

// Error:SQLSTATE[HY000]: General error: 10007 Incorrect syntax near '%PDF-1.5 %µµµµ...
$model->binary_data = fread(fopen($_FILES["file"]["tmp_name"], 'r'), filesize($_FILES["file"]["tmp_name"]));
$model->save();
---
// Error: same as above
$fileHandle = fopen($_FILES["file"]["tmp_name"], "r");
$fileContent = fread($fileHandle, filesize($_FILES["file"]["tmp_name"]));
$model->binary_data = $fileContent;
$model->save();
---
// This should work on 1.2, but I have 1.1.2
// Error: Validation failed in class Clazz 1 field had validation error: * 1 validator failed on binary_data (type)
$model->binary_data = file($_FILES["file"]["tmp_name"]);
$model->save();

这应该是直截了当的,但我无法弄清楚我做错了什么。

1 个答案:

答案 0 :(得分:0)

您可以在保存之前尝试base64_encode-ing您的数据,并在从数据库中提取数据后base64_decode