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