it-swarm.com.de

Wie erhalte ich die zuletzt eingefügte Datensatz-ID?

Ich möchte die Datensatz-ID für die zuletzt eingefügte Zeile in einer Datenbanktabelle erhalten. Ich versuche db_last_insert_id() zu verwenden, aber es wird eine Ausnahme ausgelöst.

Aufruf der undefinierten Funktion db_last_insert_id()

Wie erhalte ich die zuletzt eingefügte Datensatz-ID?

9
prashanth

In Drupal 6) würden Sie Code ähnlich dem folgenden verwenden.

db_query("INSERT INTO {mytable} (intvar, stringvar, floatvar) VALUES (%d, '%s', %f)", 5, 'hello world', 3.14);
$id = db_last_insert_id('mytable', 'id_fieldname');

Der äquivalente Code Drupal 7) lautet wie folgt.

$id = db_insert('mytable')
  ->fields(array(
    'intvar' => 5,
    'stringvar' => 'hello world',
    'floatvar' => 3.14,
  ))
  ->execute();
15
4life

Wenn Sie die jeweilige Einfügeabfrage nicht selbst steuern, können Sie immer eine einfache alte SQL-Abfrage verwenden:

$last_id = db_query('SELECT MAX(id_col) FROM {table}')->fetchField();
10
Clive

Ein grober Trick, aber es funktioniert:

$myInsertID = db_query("INSERT INTO {fred} (fld1,fld2) VALUES ('a','b')", array(), array('return' => Database::RETURN_INSERT_ID));

oder

$myInsertID = db_query("INSERT INTO {fred} (fld1,fld2) VALUES ('%s','%s')", array('a','b'), array('return' => Database::RETURN_INSERT_ID));
0
Angus Walker
  $id = db_insert('mytable')
       ->fields(array(
       'intvar' => 5,
       'stringvar' => 'hello world',
       'floatvar' => 3.14,
       ))
       ->execute();

$ id enthält die zuletzt eingefügte ID der Tabelle. Echo einfach $ id.

0
Krish

Wenn Sie aus irgendeinem Grund vor dem Einfügen einen Feldwert abrufen müssen, ist dies eine Problemumgehung.

function _get_id($tableName, $fieldName) {

    $select = db_select($tableName, 'o');
    $fields = array(
        $fieldName,
    );
    $select->fields('o', $fields);
    $result = $select->orderBy($fieldName)->range(0,1)->execute()->fetchAll();
    return $result[0];
}

$lastId = _get_id('table_name' , 'uid');
0
Rick