⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lang_cmd.cpp

📁 ncbi源码
💻 CPP
📖 第 1 页 / 共 2 页
字号:
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 + -