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

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>
            亚洲无线视频| 欧美成人激情视频免费观看| 嫩草成人www欧美| 久久综合网hezyo| 六十路精品视频| 欧美激情精品久久久久久| 欧美国产日韩二区| 99精品欧美一区二区三区综合在线| 日韩视频免费在线| 亚洲一区二区三区四区五区黄 | 欧美成人第一页| 亚洲第一色中文字幕| 亚洲第一中文字幕| 在线视频你懂得一区二区三区| 亚洲男人av电影| 久久人91精品久久久久久不卡| 免费试看一区| 国产精品一区2区| 亚洲国产婷婷香蕉久久久久久99| 在线亚洲观看| 老色鬼久久亚洲一区二区| 91久久亚洲| 久久大香伊蕉在人线观看热2| 欧美成年人在线观看| 国产精品一卡| 99国产一区二区三精品乱码| 欧美中文日韩| 亚洲美女视频网| 久久亚洲精品中文字幕冲田杏梨| 欧美日韩美女| 亚洲电影在线观看| 欧美一区1区三区3区公司| 欧美激情久久久| 久久狠狠亚洲综合| 免费91麻豆精品国产自产在线观看| 亚洲一区二区高清| 久久久综合视频| 国产麻豆一精品一av一免费| 亚洲精品视频二区| 久久精品亚洲精品| 一本色道久久88综合日韩精品 | 久久精品99国产精品| 9人人澡人人爽人人精品| 乱人伦精品视频在线观看| 国产日韩欧美一区在线 | 欧美一区二区三区免费观看| 欧美精品一区二区在线观看| 激情成人在线视频| 欧美自拍丝袜亚洲| 亚洲欧美一区二区激情| 欧美亚洲成人网| 亚洲视频一区在线| 亚洲三级电影全部在线观看高清| 久久影视三级福利片| 红杏aⅴ成人免费视频| 久久大综合网| 亚洲免费婷婷| 国产伦精品一区二区三区视频孕妇| 日韩午夜av电影| 日韩视频免费观看高清在线视频 | 欧美在线免费播放| 国产视频在线观看一区二区| 欧美与欧洲交xxxx免费观看| 亚洲午夜久久久久久久久电影院 | 久久精品在线观看| 韩国福利一区| 欧美+日本+国产+在线a∨观看| 久久黄色小说| 91久久精品日日躁夜夜躁欧美| 麻豆精品视频在线观看| 久久久亚洲国产美女国产盗摄| 精品69视频一区二区三区| 免费亚洲一区二区| 欧美超级免费视 在线| 日韩午夜激情电影| 在线性视频日韩欧美| 国产精品视频久久久| 久久精品国产久精国产爱| 久久精品国产第一区二区三区最新章节| 国产综合色在线| 亚洲国产黄色片| 国产精品视频一二| 欧美成人dvd在线视频| 欧美日韩大片一区二区三区| 午夜日韩av| 亚洲国产成人精品女人久久久| 欧美精品999| 午夜亚洲伦理| 免费成人av在线| 亚洲小说春色综合另类电影| 性欧美长视频| av成人免费在线| 性视频1819p久久| 亚洲精品自在在线观看| 亚洲午夜小视频| 亚洲激情视频在线观看| 亚洲网友自拍| 亚洲精品123区| 午夜视频久久久久久| 亚洲精品一区二区三区在线观看 | 国产一区成人| 亚洲精品乱码久久久久久按摩观| 国产麻豆精品theporn| 欧美激情一二三区| 国产视频精品va久久久久久| 亚洲全部视频| 在线精品视频在线观看高清| 亚洲一品av免费观看| 日韩视频一区二区三区在线播放| 欧美一区二区三区视频在线观看 | 一色屋精品亚洲香蕉网站| 一本久久综合| 日韩视频在线免费| 久久久久久一区| 欧美伊久线香蕉线新在线| 欧美精品粉嫩高潮一区二区| 老牛嫩草一区二区三区日本| 国产精品视频大全| 99国产精品久久久久老师 | 亚洲啪啪91| 久久久噜噜噜久久人人看| 欧美一激情一区二区三区| 欧美日韩免费一区二区三区视频 | 亚洲精品1区2区| 葵司免费一区二区三区四区五区| 久久精品国产精品| 国产亚洲欧美在线| 午夜精品av| 欧美一区二区三区视频在线观看| 欧美日韩在线一区| 99视频在线观看一区三区| 日韩一本二本av| 欧美精品在线观看| 亚洲久久一区| 亚洲私人影院在线观看| 欧美日韩三区四区| 亚洲美女黄色| 亚洲永久免费| 国产精品久久久久aaaa九色| aa级大片欧美| 亚洲一区二区三区精品动漫| 欧美日韩一区在线观看| 一区二区三区久久网| 国产人妖伪娘一区91| 亚洲一区黄色| 欧美亚洲系列| 国产日韩精品入口| 欧美在线视频播放| 蘑菇福利视频一区播放| 亚洲国产高清aⅴ视频| 欧美成人蜜桃| 夜夜爽99久久国产综合精品女不卡| 亚洲美女色禁图| 欧美三区在线视频| 亚洲欧美日韩国产另类专区| 久久精品系列| 亚洲精品国产精品乱码不99| 欧美日韩精品欧美日韩精品一| 在线视频一区二区| 久久欧美中文字幕| 亚洲精品中文字| 国产精品看片你懂得| 欧美在线影院在线视频| 亚洲第一综合天堂另类专| 亚洲调教视频在线观看| 国产视频观看一区| 欧美激情精品久久久久久大尺度 | 欧美国产三区| 亚洲综合大片69999| 美国十次成人| 亚洲午夜一区| 亚洲国产成人av| 国产精品久久久久久久免费软件| 久久国产主播精品| 99精品视频网| 欧美成人69| 午夜亚洲福利| 日韩天堂在线观看| 韩国v欧美v日本v亚洲v| 欧美伦理视频网站| 久久精品国产精品亚洲| 一区二区三区免费观看| 欧美成人免费网站| 欧美一区二区视频免费观看| 亚洲激情女人| 狠狠色狠狠色综合人人| 国产精品v日韩精品| 欧美国产日韩精品| 久久久久久**毛片大全| 亚洲先锋成人| 99综合电影在线视频| 欧美成va人片在线观看| 久久精品午夜| 欧美在线观看视频一区二区三区| 一本色道久久综合亚洲精品小说 | 国产日韩欧美亚洲一区| 欧美日韩亚洲网| 欧美黄色一区| 嫩模写真一区二区三区三州| 欧美在线一区二区三区|