mirror of
https://github.com/pocoproject/poco.git
synced 2025-01-07 09:48:04 +01:00
fix sample
This commit is contained in:
parent
fd2319d934
commit
e84788f085
@ -134,7 +134,7 @@ void sample1(Poco::MongoDB::Connection& connection)
|
|||||||
|
|
||||||
connection.sendRequest(*insertPlayerRequest);
|
connection.sendRequest(*insertPlayerRequest);
|
||||||
std::string lastError = db.getLastError(connection);
|
std::string lastError = db.getLastError(connection);
|
||||||
if ( !lastError.empty() )
|
if (!lastError.empty())
|
||||||
{
|
{
|
||||||
std::cout << "Last Error: " << db.getLastError(connection) << std::endl;
|
std::cout << "Last Error: " << db.getLastError(connection) << std::endl;
|
||||||
}
|
}
|
||||||
@ -152,15 +152,15 @@ void sample2(Poco::MongoDB::Connection& connection)
|
|||||||
cursor.query().returnFieldSelector().add("lastname", 1);
|
cursor.query().returnFieldSelector().add("lastname", 1);
|
||||||
cursor.query().returnFieldSelector().add("birthyear", 1);
|
cursor.query().returnFieldSelector().add("birthyear", 1);
|
||||||
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
||||||
while(1)
|
for (;;)
|
||||||
{
|
{
|
||||||
for(Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
for (Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
||||||
{
|
{
|
||||||
std::cout << (*it)->get<std::string>("lastname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
std::cout << (*it)->get<std::string>("lastname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
// When the cursorID is 0, there are no documents left, so break out ...
|
// When the cursorID is 0, there are no documents left, so break out ...
|
||||||
if ( response.cursorID() == 0 )
|
if (response.cursorID() == 0)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -178,15 +178,15 @@ void sample3(Poco::MongoDB::Connection& connection)
|
|||||||
|
|
||||||
Poco::MongoDB::Cursor cursor("sample", "players");
|
Poco::MongoDB::Cursor cursor("sample", "players");
|
||||||
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
||||||
while(1)
|
for (;;)
|
||||||
{
|
{
|
||||||
for(Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
for (Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
||||||
{
|
{
|
||||||
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
// When the cursorID is 0, there are no documents left, so break out ...
|
// When the cursorID is 0, there are no documents left, so break out ...
|
||||||
if ( response.cursorID() == 0 )
|
if (response.cursorID() == 0)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -206,15 +206,15 @@ void sample4(Poco::MongoDB::Connection& connection)
|
|||||||
cursor.query().selector().add("birthyear", 1978);
|
cursor.query().selector().add("birthyear", 1978);
|
||||||
|
|
||||||
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
||||||
while(1)
|
for (;;)
|
||||||
{
|
{
|
||||||
for(Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
for (Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
||||||
{
|
{
|
||||||
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
// When the cursorID is 0, there are no documents left, so break out ...
|
// When the cursorID is 0, there are no documents left, so break out ...
|
||||||
if ( response.cursorID() == 0 )
|
if (response.cursorID() == 0)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -234,18 +234,18 @@ void sample5(Poco::MongoDB::Connection& connection)
|
|||||||
|
|
||||||
// When orderby is needed, use 2 separate documents in the query selector
|
// When orderby is needed, use 2 separate documents in the query selector
|
||||||
cursor.query().selector().addNewDocument("$query").add("birthyear", 1987);
|
cursor.query().selector().addNewDocument("$query").add("birthyear", 1987);
|
||||||
cursor.query().selector().addNewDocument("$orderby").add("lastname", 0);
|
cursor.query().selector().addNewDocument("$orderby").add("lastname", 1);
|
||||||
|
|
||||||
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
||||||
while(1)
|
for (;;)
|
||||||
{
|
{
|
||||||
for(Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
for (Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
||||||
{
|
{
|
||||||
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
// When the cursorID is 0, there are no documents left, so break out ...
|
// When the cursorID is 0, there are no documents left, so break out ...
|
||||||
if ( response.cursorID() == 0 )
|
if (response.cursorID() == 0)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -268,15 +268,15 @@ void sample6(Poco::MongoDB::Connection& connection)
|
|||||||
.add("$lte", 1980);
|
.add("$lte", 1980);
|
||||||
|
|
||||||
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
||||||
while(1)
|
for (;;)
|
||||||
{
|
{
|
||||||
for(Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
for (Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
||||||
{
|
{
|
||||||
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
// When the cursorID is 0, there are no documents left, so break out ...
|
// When the cursorID is 0, there are no documents left, so break out ...
|
||||||
if ( response.cursorID() == 0 )
|
if (response.cursorID() == 0)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -322,15 +322,15 @@ void sample8(Poco::MongoDB::Connection& connection)
|
|||||||
cursor.query().setNumberToReturn(10);
|
cursor.query().setNumberToReturn(10);
|
||||||
cursor.query().setNumberToSkip(20);
|
cursor.query().setNumberToSkip(20);
|
||||||
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
Poco::MongoDB::ResponseMessage& response = cursor.next(connection);
|
||||||
while(1)
|
for (;;)
|
||||||
{
|
{
|
||||||
for(Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
for (Poco::MongoDB::Document::Vector::const_iterator it = response.documents().begin(); it != response.documents().end(); ++it)
|
||||||
{
|
{
|
||||||
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
std::cout << (*it)->get<std::string>("lastname") << ' ' << (*it)->get<std::string>("firstname") << " (" << (*it)->get<int>("birthyear") << ')' << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
// When the cursorID is 0, there are no documents left, so break out ...
|
// When the cursorID is 0, there are no documents left, so break out ...
|
||||||
if ( response.cursorID() == 0 )
|
if (response.cursorID() == 0)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -350,7 +350,7 @@ void sample9(Poco::MongoDB::Connection& connection)
|
|||||||
query.setNumberToReturn(1);
|
query.setNumberToReturn(1);
|
||||||
Poco::MongoDB::ResponseMessage response;
|
Poco::MongoDB::ResponseMessage response;
|
||||||
connection.sendRequest(query, response);
|
connection.sendRequest(query, response);
|
||||||
if ( response.hasDocuments() )
|
if (response.hasDocuments())
|
||||||
{
|
{
|
||||||
std::cout << response.documents()[0]->toString(2) << std::endl;
|
std::cout << response.documents()[0]->toString(2) << std::endl;
|
||||||
}
|
}
|
||||||
@ -360,7 +360,7 @@ void sample9(Poco::MongoDB::Connection& connection)
|
|||||||
Poco::SharedPtr<Poco::MongoDB::QueryRequest> queryPtr = db.createQueryRequest("players");
|
Poco::SharedPtr<Poco::MongoDB::QueryRequest> queryPtr = db.createQueryRequest("players");
|
||||||
queryPtr->setNumberToReturn(1);
|
queryPtr->setNumberToReturn(1);
|
||||||
connection.sendRequest(*queryPtr, response);
|
connection.sendRequest(*queryPtr, response);
|
||||||
if ( response.hasDocuments() )
|
if (response.hasDocuments())
|
||||||
{
|
{
|
||||||
std::cout << response.documents()[0]->toString(2) << std::endl;
|
std::cout << response.documents()[0]->toString(2) << std::endl;
|
||||||
}
|
}
|
||||||
@ -383,10 +383,10 @@ void sample10(Poco::MongoDB::Connection& connection)
|
|||||||
|
|
||||||
Poco::MongoDB::ResponseMessage response;
|
Poco::MongoDB::ResponseMessage response;
|
||||||
connection.sendRequest(*command, response);
|
connection.sendRequest(*command, response);
|
||||||
if ( response.hasDocuments() )
|
if (response.hasDocuments())
|
||||||
{
|
{
|
||||||
Poco::MongoDB::Array::Ptr values = response.documents()[0]->get<Poco::MongoDB::Array::Ptr>("values");
|
Poco::MongoDB::Array::Ptr values = response.documents()[0]->get<Poco::MongoDB::Array::Ptr>("values");
|
||||||
for(int i = 0; i < values->size(); ++i )
|
for (int i = 0; i < values->size(); ++i )
|
||||||
{
|
{
|
||||||
std::cout << values->get<int>(i) << std::endl;
|
std::cout << values->get<int>(i) << std::endl;
|
||||||
}
|
}
|
||||||
@ -408,9 +408,9 @@ void sample11(Poco::MongoDB::Connection& connection)
|
|||||||
Poco::MongoDB::ResponseMessage response;
|
Poco::MongoDB::ResponseMessage response;
|
||||||
connection.sendRequest(*count, response);
|
connection.sendRequest(*count, response);
|
||||||
|
|
||||||
if ( response.hasDocuments() )
|
if (response.hasDocuments())
|
||||||
{
|
{
|
||||||
std::cout << "Count: " << response.documents()[0]->get<double>("n") << std::endl;
|
std::cout << "Count: " << response.documents()[0]->getInteger("n") << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -453,6 +453,8 @@ int main(int argc, char** argv)
|
|||||||
{
|
{
|
||||||
Poco::MongoDB::Connection connection("localhost", 27017);
|
Poco::MongoDB::Connection connection("localhost", 27017);
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
sample1(connection);
|
sample1(connection);
|
||||||
sample2(connection);
|
sample2(connection);
|
||||||
sample3(connection);
|
sample3(connection);
|
||||||
@ -466,6 +468,11 @@ int main(int argc, char** argv)
|
|||||||
sample11(connection);
|
sample11(connection);
|
||||||
sample12(connection);
|
sample12(connection);
|
||||||
sample13(connection);
|
sample13(connection);
|
||||||
|
}
|
||||||
|
catch (Poco::Exception& exc)
|
||||||
|
{
|
||||||
|
std::cerr << exc.displayText() << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user