Estoy tratando de migrar mi sitio html actual a Drupal. Tengo más de 80,000 páginas que tengo que migrar, así que pensé que en lugar de sentarme frente a una computadora durante 50 años crearía un módulo. Pude crear un script que extrae el html de cada directorio y ahora llegué a un obstáculo en el que necesito crear un nodo. Estoy tratando de crear un nuevo nodo usando node_save()
, pero cuando se ejecuta node_save, obtengo un PDOException
error con todo lo que intento. Estoy pasando $node
, que es una matriz que luego se convierte en un objeto.
PDOException: en field_sql_storage_field_storage_write () (línea 424 de /srv/www/htdocs/modules/field/modules/field_sql_storage/field_sql_storage.module).
Así es como estamos creando el nodo actualmente, pero produce un error:
$node= array(
'uid' => $user->uid,
'name' => $user->name,
'type' => 'page',
'language' => LANGUAGE_NONE,
'title' => $html['title'],
'status' => 1,
'promote' => 0,
'sticky' => 0,
'created' => (int)REQUEST_TIME,
'revision' => 0,
'comment' => '1',
'menu' => array(
'enabled' => 0,
'mlid' => 0,
'module' => 'menu',
'hidden' => 0,
'has_children' => 0,
'customized' => 0,
'options' => array(),
'expanded' => 0,
'parent_depth_limit' => 8,
'link_title' => '',
'description' => '',
'parent' => 'main-menu:0',
'weight' => '0',
'plid' => '0',
'menu_name' => 'main-menu',
),
'path' => array(
'alias' => '',
'pid' => null,
'source' => null,
'language' => LANGUAGE_NONE,
'pathauto' => 1,
),
'nid' => null,
'vid' => null,
'changed' => '',
'additional_settings__active_tab' => 'edit-menu',
'log' => '',
'date' => '',
'submit' => 'Save',
'preview' => 'Preview',
'private' => 0,
'op' => 'Save',
'body' => array(LANGUAGE_NONE => array(
array(
'value' => $html['html'],
'summary' => $link,
'format' => 'full_html',
),
)),
'validated' => true,
);
node_save((object)$node);
// Small hack to link revisions to our test user.
db_update('node_revision')
->fields(array('uid' => $node->uid))
->condition('vid', $node->vid)
->execute();
En lugar de convertir una matriz en un
stdClass
objeto, puede intentar crear un nuevostdClass()
objeto y luego usar node_object_prepare () para preparar el objeto para crear un nuevo nodo y finalmente cambiar manualmente los valores de uid, nombre, título, idioma, cuerpo, etc. Además, asegúrese de usar node_submit () antes de guardar el nuevo nodo en la base de datos.Ejemplo: http://drupal.org/node/1173136
fuente
Su problema es que está intentando crear un nuevo nodo con nid = null y vid = null, lo que está arruinando la tabla de nodos mientras intenta insertar nuevos registros con el número de índice 0, lo que está creando un problema de entradas duplicadas y confuso núcleo de drupal. Por cierto, drupal core es vulnerable a acciones tales como node_save no verá el problema e intentará insertar ese registro en el db, que está causando un error de sql, y lanzar una excepción PDO
fuente