我最近决定学习MySQL++
并且在开始时遇到了一些麻烦。无论如何,我正在尝试制作一个程序来存储最新版本的程序(以帮助Homebrew)。
main.cpp中:
#include <mysql++/mysql++.h>
#include <stdlib.h>
using namespace std;
using namespace mysqlpp;
int main() {
Connection conn (false);
conn.connect ("db.ssqls", "localhost");
Query query = conn.query();
query << "SELECT * FROM version;";
StoreQueryResult ares = query.store();
for (size_t i = 0; i < ares.num_rows(); i++)
cout << "Name: " << ares[i]["name"] << " - Address: " << ares[i]["address"] << endl;
return (EXIT_SUCCESS);
}
我用g++ -lmysqlpp -g main.cpp -o main -DMYSQLPP_MYSQL_HEADERS_BURIED
编译了这个。然后我使用./main
运行它。
使用SELECT * FROM version;
在db.ssqls上运行sqlite3
会产生1|cmake|3|11|0|cmake.org|
。
当我注意到lldb
时,我正在调试(使用ares.num_rows()==0
)。事实上,似乎什么也没发生。
我的代码出了什么问题?
答案 0 :(得分:0)
嗯,事实证明,在运行MySQL
命令之前,您需要拥有MySQL
服务器。您需要在计算机上运行mysqld
。