Я пытаюсь реализовать текстовый поиск в MongoDB с помощью PHP. Я создал необходимый текстовый индекс в коллекции и запросы Mongo с операторами $ text, $ search работают нормально. Однако, используя PHP, я сталкиваюсь с несколькими ошибками для поиска документов в коллекции mongodb.текстовый поиск в mongodb - php
Вот мой код:
<html>
<body>
<h3>MongoDB Test</h3>
<h2>Text search - Amazon reviews</h2>
<br>
<form method="post">
search: <input type="text" name="term"><br><br>
<input type="submit">
</form>
</body>
</html>
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$term = $_REQUEST['term'];
// connect to mongodb : default is localhost:27017
$m = new MongoClient();
echo "Connection to database successfully"."</br>";
// select a database
$db = $m->selectDB('test');
$collection = new MongoCollection($db, 'reviews');
$query = array('$text' => array('$search'=> $term));
$cursor = $collection->find($query);
var_dump($cursor);
echo '<table border="1"><tr><td>Review Title</td><td>Author</td><td>Rating</td></tr>';
foreach ($cursor as $doc) {
echo '<tr>';
echo '<td>'.$doc['Reviews.Title'].'</td>'.
'<td>'.$doc['Reviews.Author'].'</td>'.
'<td>'.$doc['Reviews.Overall'].'</td>';
echo '</tr>';
}
echo '</table>';
}
?>
Error: Connection to database successfully object(MongoCursor)#4 (0) { } Notice: Undefined index: Reviews.Title in C:\xampp\htdocs\MongoSearch\index.php on line 41
Примечание: Undefined индекс: Reviews.Author в C: \ XAMPP \ HTDOCS \ MongoSearch \ index.php в строке 42
Notice: Undefined индекс: Reviews.Overall в C: \ XAMPP \ HTDOCS \ MongoSearch \ index.php в строке 43
Примечание: Undefined индекс: Reviews.Title в C: \ XAMPP \ HTDOCS \ MongoSearch \ index.php в строке 41
Примечание: Undefined индекс: Reviews.Author в C: \ XAMPP \ HTDOCS \ MongoSearch \ index.php в строке 42
Примечание: Undefined индекс: Reviews.Overall в C: \ XAMPP \ HTDOCS \ MongoSearch \ index.php on line 43
Может кто-нибудь указать на ошибку в этом коде? Текстовый индекс правильно построен в этой коллекции. Ниже mongo запрос отлично работает в коллекции.
db.getCollection('reviews').find({$text: {$search : 'terrible'}})
Это структура полученного документа:
{
"_id" : ObjectId("571a3c99fef93833794475d4"),
"Reviews" : {
"Title" : "Terrible, Terrible, Terrible!",
"Author" : "authoradasdjlasd",
"Overall" : "1.0",
"Content" : "battery will die.I hope this helps!!",
"Date" : "September 9, 2013"
},
"ProductInfo" : {
"Name" : "Kyocera Rise (Virgin Mobile)",
"ProductID" : "B008P2UVT0"
}
}
Основная проблема здесь состоит в том, что я получаю 0 документов в качестве результата. Я сомневаюсь в переводе текста манго на PHP-код. т.е.
$query = array('$text' => array('$search'=> $term));
$cursor = $collection->find($query);
Привет, я редактировал мой вопрос. Я также добавил структуру своего документа. Вы правы, что в $ doc нет отзывов вообще, но мой главный вопрос касается только этого. Почему я получаю 0 документов с использованием PHP, когда я уже получаю документы с обычным mongo-запросом с использованием оболочки mongo. Что-то не так в переводе запросов на PHP? –
хорошо $ doc ['Reviews'] ['Title'] сделал трюк. Благодаря!! –