我在这里面临一个情况。
我有一个内容类型 A,其中有一个图像字段(field_upload_snaps)。还有另一种内容类型 B,它也包含一个图像字段(field_valid_snaps)。
现在用户将从 A 内容类型上传图片。因此,如果用户通过 A 上传 3 张图片,则将在 Drupal 7 的 file_managed 表中创建 3 个 FID 及其相应的 URI。
现在我有一个要求,我必须使用 Drupal 代码以编程方式插入 3 个图像中的 2 个。现在不需要在公共 URI 中生成任何新的图像副本,因为图像已经通过 A 存在。
我尝试了两种方法:-
1) 我创建了一个 B 类新节点。我尝试从现有的 fid 中获取文件 URI、文件大小、filemime 和所有相关参数,并使用它与节点相关联。
global $user;
$node = new stdClass();
$node->type = "user_slideshow_snaps";
$node->language = LANGUAGE_NONE;
node_object_prepare($node);
$node->uid = $user->uid;
$file = (object) array(
'uid' => $user->uid,
'uri' => 'public://1.jpeg" ,
'filemime' => 'image/jpeg',
'status' => 1,
);
$node->field_upload_snaps['und'][] = (array)$file;
$node = node_submit($node); // Prepare node for a submit
node_save($node);
但它给了我一个错误,“不能在 file_managed 中插入重复值”。它会给出,因为这样的值已经存在于通过 A 的 file_managed 中。所以我无法保存值。
2)我先保存节点,然后像这样手动插入图像字段。
global $user;
$node = new stdClass();
$node->type = "user_slideshow_snaps";
$node->language = LANGUAGE_NONE;
node_object_prepare($node);
$node->uid = $user->uid;
$node = node_submit($node); // Prepare node for a submit
node_save($node);
db_insert('field_data_field_valid_snaps')
->fields(array(
'entity_type' => 'node',
'bundle' => 'user_actualD_snaps',
'deleted'=> 0,
'entity_id'=>$node->nid,
'delta'=>0,
'field_valid_snaps_fid'=>517,
'field_valid_snaps_alt'=>'',
'field_valid_snaps_title'=>'',
'field_valid_snaps_width'=>200,
'field_valid_snaps_height'=>300,
))
->execute();
但是在这种情况下, node_save() 之后的行不会执行。所以我无法保存它。
是否有任何功能可以将现有图像映射到另一个表中?