我在使用 mysql c++ 驱动程序转义字符串时遇到问题。我通过阅读 mysql 论坛找到了一个小例子,以下似乎是正确的方法。但是,动态转换似乎不起作用。有没有人有任何见识?谢谢!
PS“conn”是我的 Connection 对象。它保证在这一点上被分配,所以这不是问题。
编辑:添加类构造函数以完成代码示例。
DbConnector::DbConnector(const ns4__ServerHostResponse &response)
{
try
{
driver = get_driver_instance();
conn.reset(
driver->connect(boost::str(boost::format("tcp://%1%:3306") % response.DatabaseHostName), response.Username, response.Password));
conn->setSchema(response.DbSchema);
query << "";
}
catch(std::exception &ex)
{
throw CustomException(boost::str(boost::format("Unable to connect to database: %1%") % response.DbSchema), ex.what());
}
catch(...)
{
throw StokedTcpException(boost::str(boost::format("Unable to connect to database: %1%") % response.DbSchema));
}
}
void DbConnector::EscapeString(std::string &s) {
if (conn)
{
std::shared_ptr<sql::mysql::MySQL_Connection> mysqlConn(dynamic_cast<sql::mysql::MySQL_Connection*>(conn.get()));
if (mysqlConn)
s = mysqlConn->escapeString(s);
else
throw CustomException("Cannot allocate connection object to escape mysql string!");
}
}