回答:
Drupal 6では、次のコードを使用できます。
$node = node_load(array('title' => 'node title'));
ノードのタイプもわかっている場合は、次のコードを使用できます。
$node = node_load(array('title' => 'node title', 'type' => 'page'));
node_load()は常に単一のノードを返します。これは、関数がdb_query()から返されたデータベースクエリ結果リソースをループしないためです。
if ($revision) {
array_unshift($arguments, $revision);
$node = db_fetch_object(db_query('SELECT ' . $fields . ' FROM {node} n INNER JOIN {users} u ON u.uid = n.uid INNER JOIN {node_revisions} r ON r.nid = n.nid AND r.vid = %d WHERE ' . $cond, $arguments));
}
else {
$node = db_fetch_object(db_query('SELECT ' . $fields . ' FROM {node} n INNER JOIN {users} u ON u.uid = n.uid INNER JOIN {node_revisions} r ON r.vid = n.vid WHERE ' . $cond, $arguments));
}
node_load()
。これを反映するように質問タグを編集しました。
$conditions
パラメーターを使用):$nodes = node_load_multiple(array(), array('title' => 'node title'));
Drupal 7では、のパラメーターnode_load()
が変更されました。いくつかの条件に一致するノードを取得するには、EntityFieldQueryクラスを使用する必要があります。
$query = new EntityFieldQuery();
$entities = $query->entityCondition('entity_type', 'node')
->propertyCondition('type', 'your_node_type')
->propertyCondition('title', 'your node title')
->propertyCondition('status', 1)
->range(0,1)
->execute();
if (!empty($entities['node'])) {
$node = node_load(array_shift(array_keys($entities['node'])));
}
ここに、より簡単な方法があります(すでにCliveとSOで提案されています):
$nodes = node_load_multiple(NULL, array("title" => "Foo Bar"));
$node = current($nodes);
EntityFieldQueryクラスを使用するよりもはるかに覚えやすいです。
参照:SO でのDrupal 7でのタイトルによるプログラムによるノードの取得
@todo Remove $conditions in Drupal 8.
Drupal 8でも
$nids = \Drupal::entityQuery('node')
->condition('title', 'YourNodeTitle')
->sort('nid', 'DESC')
->execute();
そして次:
$node = \Drupal\node\Entity\Node::load(HEREYOUNODEID);
あなたが必要とすることを忘れないでください
use Drupal\node\Entity\Node;
arg(1)
、すべてのページでnode / Xになります。node_load()
NIDのみで動作します