📄 lang_cmd.cpp
字号:
CTDS_LangCmd::~CTDS_LangCmd(){ if (m_BR) *m_BR = 0; if (m_WasSent) Cancel();}bool CTDS_LangCmd::x_AssignParams(){ static const char s_hexnum[] = "0123456789ABCDEF"; for (unsigned int n = 0; n < m_Params.NofParams(); n++) { if(m_Params.GetParamStatus(n) == 0) continue; const string& name = m_Params.GetParamName(n); CDB_Object& param = *m_Params.GetParam(n); char val_buffer[16*1024]; const char* type; string cmd; if (name.length() > kTDSMaxNameLen) return false; switch (param.GetType()) { case eDB_Int: type = "int"; break; case eDB_SmallInt: type = "smallint"; break; case eDB_TinyInt: type = "tinyint"; break; case eDB_BigInt: type = "numeric"; break; case eDB_Char: case eDB_VarChar: type = "varchar(255)"; break; case eDB_LongChar: { CDB_LongChar& lc = dynamic_cast<CDB_LongChar&> (param); sprintf(val_buffer, "varchar(%d)", lc.Size()); type= val_buffer; break; } case eDB_Binary: case eDB_VarBinary: type = "varbinary(255)"; break; case eDB_LongBinary: { CDB_LongBinary& lb = dynamic_cast<CDB_LongBinary&> (param); if(lb.DataSize()*2 > (sizeof(val_buffer) - 4)) return false; sprintf(val_buffer, "varbinary(%d)", lb.Size()); type= val_buffer; break; } case eDB_Float: type = "real"; break; case eDB_Double: type = "float"; break; case eDB_SmallDateTime: type = "smalldatetime"; break; case eDB_DateTime: type = "datetime"; break; default: return false; } cmd += "declare " + name + ' ' + type + "\nselect " + name + " = "; if (!param.IsNULL()) { switch (param.GetType()) { case eDB_Int: { CDB_Int& val = dynamic_cast<CDB_Int&> (param); sprintf(val_buffer, "%d\n", val.Value()); break; } case eDB_SmallInt: { CDB_SmallInt& val = dynamic_cast<CDB_SmallInt&> (param); sprintf(val_buffer, "%d\n", (int) val.Value()); break; } case eDB_TinyInt: { CDB_TinyInt& val = dynamic_cast<CDB_TinyInt&> (param); sprintf(val_buffer, "%d\n", (int) val.Value()); break; } case eDB_BigInt: { CDB_BigInt& val = dynamic_cast<CDB_BigInt&> (param); sprintf(val_buffer, "%lld\n", val.Value()); break; } case eDB_Char: { CDB_Char& val = dynamic_cast<CDB_Char&> (param); const char* c = val.Value(); // No more than 255 chars size_t i = 0; val_buffer[i++] = '\''; while (*c) { if (*c == '\'') val_buffer[i++] = '\''; val_buffer[i++] = *c++; } val_buffer[i++] = '\''; val_buffer[i++] = '\n'; val_buffer[i] = '\0'; break; } case eDB_VarChar: { CDB_VarChar& val = dynamic_cast<CDB_VarChar&> (param); const char* c = val.Value(); size_t i = 0; val_buffer[i++] = '\''; while (*c) { if (*c == '\'') val_buffer[i++] = '\''; val_buffer[i++] = *c++; } val_buffer[i++] = '\''; val_buffer[i++] = '\n'; val_buffer[i] = '\0'; break; } case eDB_LongChar: { CDB_LongChar& val = dynamic_cast<CDB_LongChar&> (param); const char* c = val.Value(); size_t i = 0; val_buffer[i++] = '\''; while (*c && (i < (sizeof(val_buffer)-3))) { if (*c == '\'') val_buffer[i++] = '\''; val_buffer[i++] = *c++; } val_buffer[i++] = '\''; val_buffer[i++] = '\n'; val_buffer[i] = '\0'; if(*c != '\0') return false; break; } case eDB_Binary: { CDB_Binary& val = dynamic_cast<CDB_Binary&> (param); const unsigned char* c = (const unsigned char*) val.Value(); size_t i = 0, size = val.Size(); val_buffer[i++] = '0'; val_buffer[i++] = 'x'; for (size_t j = 0; j < size; j++) { val_buffer[i++] = s_hexnum[c[j] >> 4]; val_buffer[i++] = s_hexnum[c[j] & 0x0F]; } val_buffer[i++] = '\n'; val_buffer[i++] = '\0'; break; } case eDB_VarBinary: { CDB_VarBinary& val = dynamic_cast<CDB_VarBinary&> (param); const unsigned char* c = (const unsigned char*) val.Value(); size_t i = 0, size = val.Size(); val_buffer[i++] = '0'; val_buffer[i++] = 'x'; for (size_t j = 0; j < size; j++) { val_buffer[i++] = s_hexnum[c[j] >> 4]; val_buffer[i++] = s_hexnum[c[j] & 0x0F]; } val_buffer[i++] = '\n'; val_buffer[i++] = '\0'; break; } case eDB_LongBinary: { CDB_LongBinary& val = dynamic_cast<CDB_LongBinary&> (param); const unsigned char* c = (const unsigned char*) val.Value(); size_t i = 0, size = val.DataSize(); val_buffer[i++] = '0'; val_buffer[i++] = 'x'; for (size_t j = 0; j < size; j++) { val_buffer[i++] = s_hexnum[c[j] >> 4]; val_buffer[i++] = s_hexnum[c[j] & 0x0F]; } val_buffer[i++] = '\n'; val_buffer[i++] = '\0'; break; } case eDB_Float: { CDB_Float& val = dynamic_cast<CDB_Float&> (param); sprintf(val_buffer, "%E\n", (double) val.Value()); break; } case eDB_Double: { CDB_Double& val = dynamic_cast<CDB_Double&> (param); sprintf(val_buffer, "%E\n", val.Value()); break; } case eDB_SmallDateTime: { CDB_SmallDateTime& val = dynamic_cast<CDB_SmallDateTime&> (param); sprintf(val_buffer, "'%s'\n",val.Value().AsString("M/D/Y h:m").c_str()); break; } case eDB_DateTime: { CDB_DateTime& val = dynamic_cast<CDB_DateTime&> (param); sprintf(val_buffer, "'%s:%.3d'\n", val.Value().AsString("M/D/Y h:m:s").c_str(), (int)(val.Value().NanoSecond()/1000000)); break; } default: return false; // dummy for compiler } cmd += val_buffer; } else cmd += "NULL\n"; if (dbcmd(m_Cmd, (char*) cmd.c_str()) != SUCCEED) return false; } return true;}END_NCBI_SCOPE/* * =========================================================================== * $Log: lang_cmd.cpp,v $ * Revision 1000.1 2004/06/01 19:20:51 gouriano * PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.13 * * Revision 1.13 2004/05/17 21:13:37 gorelenk * Added include of PCH ncbi_pch.hpp * * Revision 1.12 2003/06/05 16:01:40 soussov * adds code for DumpResults and for the dumped results processing * * Revision 1.11 2003/05/16 20:26:09 soussov * adds code to skip parameter if it was not set * * Revision 1.10 2003/04/29 21:15:03 soussov * new datatypes CDB_LongChar and CDB_LongBinary added * * Revision 1.9 2002/09/19 22:28:20 soussov * changs order of result processing * * Revision 1.8 2002/07/22 20:11:07 soussov * fixes the RowCount calculations * * Revision 1.7 2002/01/14 20:38:49 soussov * timeout support for tds added * * Revision 1.6 2001/12/18 19:29:08 soussov * adds conversion from nanosecs to milisecs for datetime args * * Revision 1.5 2001/12/18 17:56:39 soussov * copy-paste bug in datetime processing fixed * * Revision 1.4 2001/12/18 16:42:44 soussov * fixes bug in datetime argument processing * * Revision 1.3 2001/12/13 23:40:53 soussov * changes double quotes to single quotes in SQL queries * * Revision 1.2 2001/11/06 18:00:02 lavr * Formatted uniformly as the rest of the library * * Revision 1.1 2001/10/25 00:39:22 vakatov * Initial revision * * =========================================================================== */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -