0

我是一个新人使用MYSQL。

代码是:

void gdns_mysql::commit_task()
    {
        if (mysql_commit(conn) != 0)
        {
            throw_trackerr_str(boost::format("MysqlCommitError %d %s") % mysql_errno(conn) % mysql_error(conn));
        }
    }

这个函数 commit_task 总是花费 6~7 秒。
我想知道为什么会这样?
请列出一些原因。谢谢

顺便说一句:查询是这样的:

void gdns_mysql::update_server_status(std::string const& server_, std::string const& status_)
    {
        stringstream sql;
        sql << "update server";
        if (!status_.empty()) sql << " set status = '" << get_escape_string(status_) << "'";
        else sql <<" set status = status_predict";
        sql << " where serverip = '" << get_escape_string(server_) << "'"
            << endl;
        execute(sql.str());
    }

zone_ptrs_t  gdns_mysql::query_zone_bykey(std::string const& zonename_)
    {
        string statement = "select * from zone";
        bool where_flag = false;
        if (!zonename_.empty())
        {
            statement += " where zonename = '" + get_escape_string(zonename_) + "'";
            where_flag = true;
        }
        select(statement);
        return fetch_datas<zone_t>();
    }
4

0 回答 0