第14章 《数据》Page56~57,“流”方式组装SQL语句

#include <iostream>
#include <mysql++/mysql++.h>

using namespace std;

//打印查询结果
void output_result(mysqlpp::StoreQueryResult const& result)
{
    size_t row_count = result.num_rows();
    if(row_count == 0)
    {
        cout << "查无记录。" << endl;
        return;
    }

    for(size_t i = 0; i < row_count; ++ i)
    {
        cout << result[i]["id"]
             << setw(6) << "=>" << setw(12)
             << result[i]["name"] << endl;
    }
}

int main()
{
    mysqlpp::Connection con;
    con.set_option(new mysqlpp::SetCharsetNameOption("gbk"));

    try
    {
        con.connect("d2school", "127.0.0.1", "root", "mysql_d2school");

        while(true)
        {
            mysqlpp::Query Q = con.query();//每次新建一个“查询”对象
            string name;
            cout << "请输入用户名: ";
            getline(cin, name);

            Q << "SELECT * FROM user WHERE name = "
              << mysqlpp::quote << name;

            mysqlpp::StoreQueryResult res = Q.store();
            output_result(res);
        }
    }
    catch(mysqlpp::Exception const& e)
    {
        cerr << "ERROR!" << e.what() << endl;
        return -1;
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值