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

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>
            国产欧美日韩在线| 午夜精品国产更新| 亚洲免费伊人电影在线观看av| 亚洲电影免费观看高清完整版在线| 国内精品久久久久久| 狠狠色狠狠色综合系列| 激情偷拍久久| 亚洲国产黄色片| 亚洲精品乱码久久久久久| 日韩视频在线一区| 亚洲手机视频| 久久精品人人做人人爽| 免费欧美在线视频| 亚洲国产精品免费| 久久久精品999| 免费欧美在线视频| 欧美日韩精品综合| 国产情侣一区| 亚洲国产精品热久久| 亚洲每日在线| 午夜精品久久久久久 | 亚洲国产精品ⅴa在线观看 | 欧美精品一区二区三| 国产精品多人| 合欧美一区二区三区| 亚洲精品永久免费| 欧美一区二区在线免费观看| 麻豆精品视频在线| 亚洲免费av片| 久久精品视频在线播放| 欧美区一区二| 韩日精品视频| 亚洲综合久久久久| 亚洲成人在线视频播放| 亚洲国产精品久久久| 一区二区三区国产精华| 久久精品国产亚洲一区二区| 欧美日韩综合在线免费观看| 在线看片一区| 久久精品日韩| 亚洲少妇自拍| 久久精品一二三区| 欧美成人午夜激情| 性欧美xxxx视频在线观看| 欧美高清在线播放| 在线国产亚洲欧美| 久久se精品一区二区| 99在线热播精品免费99热| 久久一区二区三区国产精品| 国产免费亚洲高清| 亚洲欧美韩国| 一本色道久久综合精品竹菊| 你懂的视频欧美| 国模精品一区二区三区色天香| 亚洲一区精品视频| 日韩亚洲欧美一区| 欧美精品一区二区视频| 亚洲国产精品va在看黑人| 麻豆成人av| 久久婷婷成人综合色| 极品少妇一区二区三区精品视频| 欧美一区二区三区免费观看| 亚洲午夜伦理| 国产精品国色综合久久| 亚洲午夜久久久久久久久电影院| 亚洲日本免费| 欧美日韩国产精品专区| 一片黄亚洲嫩模| 亚洲国产美女| 激情综合视频| 久久久噜噜噜| 久久久久久久高潮| 韩国美女久久| 欧美激情精品久久久久久黑人| 久久久99国产精品免费| 影音先锋亚洲视频| 欧美激情一区二区三区不卡| 欧美成人精品不卡视频在线观看 | 国产精品亚洲综合色区韩国| 亚洲在线国产日韩欧美| 亚洲一区影音先锋| 国产女主播一区二区| 久久综合婷婷| 欧美黑人在线观看| 午夜精品视频在线观看| 久久精品国产精品亚洲综合| 亚洲国内精品在线| 一区二区久久久久久| 国产性色一区二区| 国产欧美日韩综合一区在线播放| 欧美一区二区三区电影在线观看| 欧美中在线观看| 亚洲精品日本| 亚洲女同在线| 亚洲精品免费观看| 亚洲一区观看| 91久久夜色精品国产九色| 制服丝袜激情欧洲亚洲| 激情五月综合色婷婷一区二区| 亚洲韩国青草视频| 国产精品亚洲综合久久| 欧美黄色小视频| 国产农村妇女精品| 亚洲国产精品视频| 国产精品人成在线观看免费 | 久久午夜羞羞影院免费观看| 亚洲区一区二| 性欧美大战久久久久久久免费观看| 亚洲国产精品久久久久婷婷老年 | 欧美成人性网| 国产精品久久久久毛片软件| 欧美成人精品在线视频| 国产精品美女在线| 91久久精品国产91久久性色tv| 国产欧美精品xxxx另类| 亚洲精品一区在线| 在线观看日韩| 欧美一区二区三区四区视频| 中文精品99久久国产香蕉| 男男成人高潮片免费网站| 久久久999精品视频| 欧美性一区二区| 91久久久久久久久| 在线观看亚洲视频啊啊啊啊| 亚洲欧美另类中文字幕| 免费日韩视频| 美女精品网站| 久久天天躁狠狠躁夜夜av| 欧美先锋影音| 99ri日韩精品视频| 99re热这里只有精品视频 | 欧美成人中文| 国模精品一区二区三区色天香| 亚洲视频一区二区在线观看 | 午夜精品一区二区三区在线视 | 欧美日韩另类在线| 欧美国产日韩视频| 亚洲国产成人久久| 两个人的视频www国产精品| 久久久噜噜噜久久| 黄色成人精品网站| 久久久999精品免费| 久久婷婷国产综合尤物精品| 国产一级一区二区| 欧美专区第一页| 巨胸喷奶水www久久久免费动漫| 狠狠色伊人亚洲综合成人| 久久久水蜜桃av免费网站| 裸体歌舞表演一区二区| 亚洲国产小视频| 欧美mv日韩mv国产网站| 亚洲电影在线免费观看| 亚洲裸体俱乐部裸体舞表演av| 欧美国产精品人人做人人爱| 亚洲欧洲一区二区在线播放| 一区二区三区国产| 欧美体内谢she精2性欧美| 亚洲一区二区三区国产| 久久免费精品视频| 91久久精品美女高潮| 欧美乱大交xxxxx| 亚洲一区二区免费| 美女尤物久久精品| 日韩亚洲视频在线| 国产精品手机视频| 久久久久国产精品一区二区| 亚洲国产乱码最新视频| 亚洲欧美综合精品久久成人 | 欧美精品成人91久久久久久久| 亚洲精品在线观看免费| 午夜精品美女久久久久av福利| 黄色另类av| 欧美日韩成人综合在线一区二区| 亚洲一区二区三区四区中文| 久久偷窥视频| 亚洲视频专区在线| 激情综合网激情| 欧美亚洲不卡| 久久午夜影视| 亚洲欧美日韩一区在线| 亚洲国产一区二区a毛片| 欧美亚洲免费高清在线观看| 亚洲日韩欧美一区二区在线| 国产欧美日韩麻豆91| 欧美精品一区二区三| 久久久精品性| 亚洲自拍偷拍麻豆| 亚洲精品中文字幕在线| 亚洲一区二区在线免费观看| 欧美91大片| 欧美亚洲视频| 亚洲视频1区2区| 亚洲福利视频一区二区| 国产欧美日韩在线| 欧美日韩精品中文字幕| 美日韩在线观看| 久久精品视频99| 亚洲午夜一区二区三区| 亚洲人成亚洲人成在线观看图片| 久久久久久久91|