青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Codejie's C++ Space

Using C++

C++: c++ wrap for libpq


class DBConnection
{
public:
    class TParams
    {
    public:
        TParams(int size);
        virtual ~TParams();
    private:
        TParams(const TParams& params) {}
        TParams& operator = (const TParams& params) { return *this; }
    public:
        void Add(const char* val, int size);
        void Add(int val);
        void Add(unsigned int val);
        void Add(uint64_t val);
        void Add(short val);
        
        void Free();
        
        int Size() const { return _size; }
        const char * const * Value() const { return value; }
        const int* Length() const { return length; }
        const int* Format() const { return format; }
    public:
        char** value;
        int* length;
        int* format;
    private:
        int _size;
        int _pos;
    };
public:
    DBConnection()
    : conn(NULL)
    {
    }
    virtual ~DBConnection();
public:
    int Connect(const char* info);
    void Disconnect();
    
    int ExecCmd(const char* cmd);
    PGresult* ExecQuery(const char* sql);
    int ExecCmdWithParams(const char* cmd, const TParams& params);
    PGresult* ExecQueryWithParams(const char* sql, const TParams& params);
    int BeginTranscation();
    int EndTranscation();
private:
    PGconn* conn;
};



DBConnection::TParams::TParams(int size)
: _size(size), _pos(0)
{
    value = new char*[_size];
    length = new int[_size];
    format = new int[_size];
}

DBConnection::TParams::~TParams()
{
    Free();
}

void DBConnection::TParams::Free()
{
    if (_size == 0)
    {
        return;
    }
    
    for (int i = 0; i < _size; ++ i)
    {
        if (format[i] == 0)
        {
            delete[] value[i];
        }
        else if (length[i] == sizeof(int) || length[i] == sizeof(unsigned int))
        {
            delete (int*)value[i];
        }
        else if (length[i] == sizeof(uint64_t))
        {
            delete (uint64_t*)value[i];
        }
        else
        {
            delete (short*)value[i];
        }
    }
    
    delete[] value, value = NULL;
    delete[] length, length = NULL;
    delete[] format, format = NULL;
    
    _size = 0;
    
    DEBUG(DEBUG_ANY, "<DBConnection::TParams::Free()>"<< std::endl);
}

void DBConnection::TParams::Add(const char* val, int size)
{
    char* char_val = new char[size + 1];
    char_val[size] = '\0';
//    char* char_val = new char[size];
    memcpy(char_val, val, size);
    
    value[_pos] = char_val;
    length[_pos] = size + 1;
    format[_pos] = 0;
    
    ++ _pos;
}

void DBConnection::TParams::Add(int val)
{
#ifdef __OS_MAC__
    int* int_val = new (int)(val);
#else
    int* int_val = new (int)(htonl(val));
#endif
    value[_pos] = (char*)(int_val);
    length[_pos] = sizeof(int);
    format[_pos] = 1;
    
    ++ _pos;
}

void DBConnection::TParams::Add(unsigned int val)
{
#ifdef __OS_MAC__
    unsigned int* int_val = new (unsigned int)(val);
#else
    unsigned int* int_val = new (unsigned int)(htonl(val));
#endif

    value[_pos] = (char*)(int_val);
    length[_pos] = sizeof(int);
    format[_pos] = 1;
    
    ++ _pos;
}

void DBConnection::TParams::Add(uint64_t val)
{
#ifdef __OS_MAC__
    uint64_t* uint64_val = new uint64_t(val);
#else
    uint64_t* uint64_val = new uint64_t(htobe64(val));
#endif
    value[_pos] = (char*)(uint64_val);
    length[_pos] = sizeof(uint64_t);
    format[_pos] = 1;
    
    ++ _pos;
}

void DBConnection::TParams::Add(short val)
{
#ifdef __OS_MAC__
    short* int_val = new (short)(val);
#else
    short* int_val = new (short)(htons(val));
#endif
    value[_pos] = (char*)(int_val);
    length[_pos] = sizeof(short);
    format[_pos] = 1;
    
    ++ _pos;
}

////

DBConnection::~DBConnection()
{
    Disconnect();
}

int DBConnection::Connect(const char* info)
{
    conn = PQconnectdb(info);
    if (PQstatus(conn) != CONNECTION_OK)
    {
        DEBUG(DEBUG_ANY, "PQ connection failed.");
        PQfinish(conn);
        return -1;
    }
    
    return 0;
}

void DBConnection::Disconnect()
{
    if (conn != NULL)
    {
        PQfinish(conn);
        conn = NULL;
    }
}

int DBConnection::ExecCmd(const char* cmd)
{
    PGresult* res = PQexec(conn, cmd);
    if (PQresultStatus(res) != PGRES_COMMAND_OK)
    {
        DEBUG(DEBUG_ANY, "<DBConnection::ExecCmd> failed - " << cmd << std::endl);
        DEBUG(DEBUG_ANY, "DBConnection::ExecCmd> error - " << PQerrorMessage(conn) << std::endl);
        PQclear(res);
        return -1;
    }
    //    int ret = ntohl(*PQcmdTuples(res));
    int ret = *PQcmdTuples(res);
    PQclear(res);
    return ret;
}

PGresult* DBConnection::ExecQuery(const char* sql)
{
    PGresult* res = PQexec(conn, sql);
    if (PQresultStatus(res) != PGRES_TUPLES_OK)
    {
        DEBUG(DEBUG_ANY, "<DBConnection::ExecQuery> failed - " << sql << std::endl);
        DEBUG(DEBUG_ANY, "DBConnection::ExecQuery> error - " << PQerrorMessage(conn) << std::endl);
        PQclear(res);
        return NULL;
    }
    return res;
}

int DBConnection::ExecCmdWithParams(const char* cmd, const DBConnection::TParams& params)
{
    PGresult* res = PQexecParams(conn, cmd, params.Size(), NULL, params.Value(), params.Length(), params.Format(), 0);
    if (PQresultStatus(res) != PGRES_COMMAND_OK)
    {
        DEBUG(DEBUG_ANY, "<DBConnection::ExecCmdWithParams> failed - " << cmd << std::endl);
        DEBUG(DEBUG_ANY, "DBConnection::ExecCmdWithParams> error - " << PQerrorMessage(conn) << std::endl);
        PQclear(res);
        return -1;
    }
//    int ret = ntohl(*PQcmdTuples(res));
    int ret = *PQcmdTuples(res);
    PQclear(res);
    
    DEBUG(DEBUG_ANY, "<DBConnection::ExecCmdWithParams> succ - " << cmd << std::endl);
    
    return ret;
//    return 0;
}

PGresult* DBConnection::ExecQueryWithParams(const char* sql, const TParams& params)
{
    PGresult* res = PQexecParams(conn, sql, params.Size(), NULL, params.Value(), params.Length(), params.Format(), 0);
    if (PQresultStatus(res) != PGRES_TUPLES_OK)
    {
        DEBUG(DEBUG_ANY, "<DBConnection::ExecQueryWithParams> failed - " << sql << std::endl);
        DEBUG(DEBUG_ANY, "DBConnection::ExecQueryWithParams> error - " << PQerrorMessage(conn) << std::endl);
        PQclear(res);
        return NULL;
    }
    return res;
}

int DBConnection::BeginTranscation()
{
    return ExecCmd("BEGIN");
}

int DBConnection::EndTranscation()
{
    return ExecCmd("END");
}





posted on 2015-01-10 00:49 codejie 閱讀(2967) 評論(1)  編輯 收藏 引用 所屬分類: C++

評論

# re: C++: c++ wrap for libpq 2016-03-23 11:54 豬大頭

類不錯,可惜不會使用啊。
給一個例子吧。特別
請教 class TParams 怎么樣使用?
謝謝啦。
  回復  更多評論   

公告

Using C++

導航

統計

留言簿(73)

隨筆分類(513)

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩国产一级| 亚洲国产日韩在线| 在线观看三级视频欧美| 国产精品二区三区四区| 欧美色网一区二区| 国产精品日韩高清| 国产亚洲一区二区三区| 一区三区视频| 91久久久亚洲精品| 日韩视频中午一区| 亚洲自拍都市欧美小说| 久久精品国产亚洲aⅴ| 久久精品72免费观看| 久久人91精品久久久久久不卡| 久久人人九九| 亚洲日本中文字幕区| 亚洲五月六月| 久久久青草青青国产亚洲免观| 老司机67194精品线观看| 欧美另类一区| 国产亚洲永久域名| 一区二区三区国产精品| 久久天堂成人| 在线一区二区视频| 狼人社综合社区| 国产农村妇女精品一二区| 亚洲国产精品成人综合| 午夜在线视频观看日韩17c| 蜜桃久久av| 亚洲综合久久久久| 欧美精品自拍| 亚洲黄色有码视频| 久久久国产精彩视频美女艺术照福利| 欧美黄色小视频| 小黄鸭精品密入口导航| 欧美日韩国产页| 亚洲高清激情| 欧美一区二区高清在线观看| 亚洲国产精品第一区二区| 亚洲欧美久久久| 国产一区二区三区观看 | 亚洲黄色免费| 99在线观看免费视频精品观看| 亚洲欧美www| 欧美成人亚洲成人| 好吊色欧美一区二区三区四区| 亚洲影视在线| 亚洲人在线视频| 男女精品视频| 亚洲高清123| 美日韩精品免费观看视频| 午夜在线a亚洲v天堂网2018| 国产精品porn| 亚洲欧美国产精品va在线观看| 亚洲三级电影在线观看 | 欧美日韩视频在线一区二区 | 久久久久欧美精品| 国产一区激情| 久久夜色精品国产亚洲aⅴ| 先锋a资源在线看亚洲| 国产精品国产三级国产专播品爱网| 亚洲人成7777| 亚洲高清视频的网址| 麻豆九一精品爱看视频在线观看免费| 国外视频精品毛片| 美女视频黄 久久| 久久综合九色综合网站| 狠狠色狠狠色综合日日小说| 久久久久久亚洲精品不卡4k岛国| 亚洲欧美日韩在线一区| 国产亚洲欧美aaaa| 久久婷婷国产综合国色天香| 久久综合九九| 一区二区三区日韩| aa级大片欧美| 国产深夜精品| 欧美成人福利视频| 欧美日韩精品福利| 欧美在线免费播放| 久久躁日日躁aaaaxxxx| 最新国产乱人伦偷精品免费网站| 亚洲欧洲在线播放| 国产精品亚洲综合| 欧美电影免费观看大全| 欧美日韩国产成人在线| 欧美在线免费看| 欧美成人69| 欧美一区二区三区四区在线观看地址| 欧美中文在线观看| 亚洲精品日韩在线| 亚洲欧美日韩在线| 亚洲激情在线| 亚洲一区二区三区777| 亚洲成人直播| 亚洲女与黑人做爰| 久久久一二三| 一区二区三区视频在线看| 亚洲免费视频成人| 91久久久在线| 欧美一级专区免费大片| 久久精品国产久精国产一老狼| 亚洲无线一线二线三线区别av| 一本色道久久综合精品竹菊| 国产欧美一区二区精品性| 欧美r片在线| 国产精品午夜在线| 亚洲国产高清在线| 国产一区二区三区在线观看网站 | 国产亚洲精品福利| 亚洲国产一区二区在线| 国产精品久久午夜夜伦鲁鲁| 美女久久网站| 国产精品色在线| 亚洲国产成人av在线 | 99re视频这里只有精品| 欧美一级理论性理论a| 亚洲午夜久久久| 免费在线国产精品| 久久综合色88| 欧美诱惑福利视频| 亚洲男人影院| 欧美日韩在线综合| 亚洲欧美国产毛片在线| 欧美大片一区二区三区| 美国三级日本三级久久99| 国产精品羞羞答答xxdd| 在线一区二区三区做爰视频网站| 91久久综合| 久久婷婷久久| 鲁大师成人一区二区三区| 国产亚洲亚洲| 欧美一区二区三区在线| 久久av二区| 国产亚洲高清视频| 欧美一二三视频| 久久精品久久99精品久久| 国产欧美亚洲精品| 午夜免费日韩视频| 久久精品最新地址| 伊人影院久久| 久久尤物视频| 亚洲国产精品va在线看黑人| 亚洲欧洲日产国产网站| 噜噜噜噜噜久久久久久91| 欧美激情性爽国产精品17p| 亚洲美女福利视频网站| 欧美日韩 国产精品| 亚洲视频二区| 久久精品30| 亚洲激情视频在线播放| 欧美国产日本在线| 在线午夜精品| 欧美在线观看视频在线| 国内精品久久久久影院优| 久久日韩精品| 亚洲日本欧美| 欧美一区二区三区四区在线 | 亚洲男人av电影| 国产精品自拍在线| 久久精品欧洲| 欧美二区在线看| 一区二区三区日韩欧美| 国产九九精品视频| 久久天堂av综合合色| 日韩一级大片| 另类天堂av| 亚洲视频一二三| 国产午夜精品在线| 欧美gay视频| 亚洲欧美美女| 亚洲国产电影| 欧美中日韩免费视频| 亚洲激情六月丁香| 国产免费观看久久黄| 免费成人高清| 亚洲一区bb| 欧美激情在线| 欧美在线观看视频在线| 亚洲国产精品成人久久综合一区 | 国产色视频一区| 久久综合一区二区三区| 国产精品99久久不卡二区| 蜜桃伊人久久| 亚欧美中日韩视频| 91久久精品国产91久久性色tv | 国产精品视频yy9099| 免费高清在线视频一区·| 亚洲最新色图| 亚洲国产精品毛片| 农村妇女精品| 久久精品123| 亚洲专区在线视频| 99re6这里只有精品视频在线观看| 国产午夜精品视频| 欧美日韩亚洲网| 美国十次成人| 久久久久一区二区三区| 亚洲一区二区三区在线视频| 亚洲激情网址| 亚洲国产日韩一区|