本文整理汇总了C++中sql::SQLString类的典型用法代码示例。如果您正苦于以下问题:C++ SQLString类的具体用法?C++ SQLString怎么用?C++ SQLString使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了SQLString类的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: if
/* {{{ MySQL_Connection::getClientOption() -I- */
void
MySQL_Connection::getClientOption(const sql::SQLString & optionName, void * optionValue)
{
CPP_ENTER_WL(intern->logger, "MySQL_Connection::getClientOption");
if (!optionName.compare("metadataUseInfoSchema")) {
*(static_cast<bool *>(optionValue)) = intern->metadata_use_info_schema;
} else if (!optionName.compare("defaultStatementResultType")) {
*(static_cast<int *>(optionValue)) = intern->defaultStatementResultType;
} else if (!optionName.compare("defaultPreparedStatementResultType")) {
*(static_cast<int *>(optionValue)) = intern->defaultPreparedStatementResultType;
} else if (!optionName.compare("multiByteMinLength")) {
MY_CHARSET_INFO cs;
proxy->get_character_set_info(&cs);
*(static_cast<int *>(optionValue)) = cs.mbminlen;
} else if (!optionName.compare("multiByteMaxLength")) {
MY_CHARSET_INFO cs;
proxy->get_character_set_info(&cs);
*(static_cast<int *>(optionValue)) = cs.mbmaxlen;
/* mysql_get_option() was added in mysql 5.7.3 version */
} else if ( proxy->get_server_version() >= 50703 ) {
try {
if (GET_CONN_OPTION(optionName, optionValue, intOptions)) {
return;
} else if (GET_CONN_OPTION(optionName, optionValue, booleanOptions)) {
return;
} else if (GET_CONN_OPTION(optionName, optionValue, stringOptions)) {
return;
}
} catch (sql::SQLUnsupportedOptionException& e) {
CPP_ERR_FMT("Unsupported option : %d:(%s) %s", proxy->errNo(), proxy->sqlstate().c_str(), proxy->error().c_str());
throw e;
}
}
}
示例2: CPP_ENTER_WL
/* {{{ MySQL_Connection::getClientOption() -I- */
void
MySQL_Connection::getClientOption(const sql::SQLString & optionName, void * optionValue)
{
CPP_ENTER_WL(intern->logger, "MySQL_Connection::getClientOption");
if (!optionName.compare("metadataUseInfoSchema")) {
*(static_cast<bool *>(optionValue)) = intern->metadata_use_info_schema;
} else if (!optionName.compare("defaultStatementResultType")) {
*(static_cast<int *>(optionValue)) = intern->defaultStatementResultType;
} else if (!optionName.compare("defaultPreparedStatementResultType")) {
*(static_cast<int *>(optionValue)) = intern->defaultPreparedStatementResultType;
} else if (!optionName.compare("characterSetResults")) {
*(static_cast<sql::SQLString **>(optionValue)) = new sql::SQLString(getSessionVariable("characterSetResults"));
}
}
示例3: CPP_ENTER_WL
/* {{{ MySQL_Connection::getClientOption() -I- */
sql::SQLString
MySQL_Connection::getClientOption(const sql::SQLString & optionName)
{
CPP_ENTER_WL(intern->logger, "MySQL_Connection::getClientOption");
if (!optionName.compare("characterSetResults")) {
return sql::SQLString(getSessionVariable("character_set_results"));
} else if (!optionName.compare("characterSetDirectory")) {
MY_CHARSET_INFO cs;
proxy->get_character_set_info(&cs);
return cs.dir ? sql::SQLString(cs.dir) : "";
} else if ( proxy->get_server_version() >= 50703 ) {
const char* optionValue= NULL;
if (GET_CONN_OPTION(optionName, &optionValue, stringOptions)) {
return optionValue ? sql::SQLString(optionValue) : "";
}
}
return "";
}
示例4: checkValid
/* {{{ MySQL_ArtResultSet::findColumn() -I- */
uint32_t
MySQL_ArtResultSet::findColumn(const sql::SQLString& columnLabel) const
{
CPP_ENTER("MySQL_ArtResultSet::columnLabel");
checkValid();
boost::scoped_array< char > upstring(sql::mysql::util::utf8_strup(columnLabel.c_str(), 0));
FieldNameIndexMap::const_iterator iter = field_name_to_index_map.find(upstring.get());
if (iter == field_name_to_index_map.end()) {
return 0;
}
/* findColumn returns 1-based indexes */
return iter->second + 1;
}
示例5: get_connection_option
bool get_connection_option(const sql::SQLString optionName,
void *optionValue,
const String2IntMap options_map[],
size_t map_size,
boost::shared_ptr< NativeAPI::NativeConnectionWrapper > &proxy)
{
for (size_t i = 0; i < map_size; ++i) {
if (!optionName.compare(options_map[i].key)) {
try {
proxy->get_option(static_cast<sql::mysql::MySQL_Connection_Options>(options_map[i].value), optionValue);
} catch (sql::InvalidArgumentException& e) {
std::string errorOption(options_map[i].key);
throw ::sql::SQLUnsupportedOptionException(e.what(), errorOption);
}
return true;
}
}
return false;
}
示例6: setHost
/* {{{ MySQL_Uri::setHost() -I- */
void MySQL_Uri::setHost(const sql::SQLString &h)
{
setProtocol(NativeAPI::PROTOCOL_TCP);
host= h.c_str();
}
示例7: parseUri
/* URI formats tcp://[host]:port/schema
unix://socket
pipe://named_pipe
*/
bool parseUri(const sql::SQLString & str, MySQL_Uri& uri)
{
if (!str.compare(0, sizeof(MYURI_SOCKET_PREFIX) - 1, MYURI_SOCKET_PREFIX))
{
uri.setSocket(str.substr(sizeof(MYURI_SOCKET_PREFIX) - 1, sql::SQLString::npos));
return true;
}
if (!str.compare(0, sizeof(MYURI_PIPE_PREFIX) - 1 , MYURI_PIPE_PREFIX))
{
uri.setPipe(str.substr(sizeof(MYURI_PIPE_PREFIX) - 1, sql::SQLString::npos));
return true;
}
sql::SQLString host;
size_t start_sep, end_sep;
/* i wonder how did it work with "- 1"*/
if (!str.compare(0, sizeof(MYURI_TCP_PREFIX) - 1, MYURI_TCP_PREFIX) )
{
host= str.substr(sizeof(MYURI_TCP_PREFIX) - 1, sql::SQLString::npos);
}
else
{
/* allowing to have port and schema specified even w/out protocol
specifier("tcp://") */
host= str.c_str();
}
if (host[0] == MYURI_HOST_BEGIN)
{
end_sep= host.find(MYURI_HOST_END);
/* No closing ] after [*/
if (end_sep == sql::SQLString::npos)
{
return false;
}
uri.setHost(host.substr(1, end_sep - 1));
/* Cutting host to continue w/ port and schema reading */
host= host.substr(end_sep + 1);
}
/* Looking where schema part begins */
start_sep = host.find('/');
if (start_sep != sql::SQLString::npos)
{
if ((host.length() - start_sep) > 1/*Slash*/)
{
uri.setSchema(host.substr(start_sep + 1, host.length() - start_sep - 1));
}
host= host.substr(0, start_sep);
}
else
{
uri.setSchema("");
}
/* Looking where port part begins*/
start_sep = host.find_last_of(':', sql::SQLString::npos);
if (start_sep != sql::SQLString::npos)
{
uri.setPort(atoi(host.substr(start_sep + 1, sql::SQLString::npos).c_str()));
host = host.substr(0, start_sep);
}
else
{
uri.setPort(DEFAULT_TCP_PORT);
}
/* If host was enclosed in [], it has been already set, and "host" variable is
empty */
if (host.length() > 0)
{
uri.setHost(host);
}
return true;
}
示例8: setPipe
/* {{{ MySQL_Uri::setPipe() -I- */
void MySQL_Uri::setPipe(const sql::SQLString &p)
{
setProtocol(NativeAPI::PROTOCOL_PIPE);
host= p.c_str();
}
示例9: setSocket
/* {{{ MySQL_Uri::setSocket() -I- */
void MySQL_Uri::setSocket(const sql::SQLString &s)
{
setProtocol(NativeAPI::PROTOCOL_SOCKET);
host= s.c_str();
}
示例10:
/* {{{ MySQL_NativeStatementWrapper::prepare() */
int
MySQL_NativeStatementWrapper::prepare(const ::sql::SQLString & stmt_str)
{
return api->stmt_prepare(stmt, stmt_str.c_str(), stmt_str.length());
}