• <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>

            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 閱讀(2931) 評(píng)論(1)  編輯 收藏 引用 所屬分類: C++

            評(píng)論

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

            類不錯(cuò),可惜不會(huì)使用啊。
            給一個(gè)例子吧。特別
            請教 class TParams 怎么樣使用?
            謝謝啦。
              回復(fù)  更多評(píng)論   

            公告

            Using C++

            導(dǎo)航

            統(tǒng)計(jì)

            留言簿(73)

            隨筆分類(513)

            積分與排名

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            色综合久久中文字幕无码| 久久免费大片| 国产Av激情久久无码天堂| 久久亚洲精品中文字幕| 久久免费国产精品一区二区| 久久久久亚洲AV无码去区首| 欧美久久一区二区三区| 精品国产一区二区三区久久久狼| 国产高清国内精品福利99久久| 久久婷婷人人澡人人爽人人爱| 国产亚洲精久久久久久无码| 麻豆国内精品久久久久久| 久久99精品久久久久久久久久| 久久久久亚洲AV无码专区网站| 久久精品国产亚洲77777| 久久人人超碰精品CAOPOREN| 97久久香蕉国产线看观看| 亚洲日本va午夜中文字幕久久| 国产精品一久久香蕉产线看| 国内精品伊人久久久久影院对白| 久久丫忘忧草产品| 国产亚洲美女精品久久久2020| 久久99精品九九九久久婷婷| av无码久久久久久不卡网站| 热久久视久久精品18| 久久天天躁狠狠躁夜夜avapp| 欧美精品一本久久男人的天堂| 日韩人妻无码精品久久久不卡 | 久久国产成人亚洲精品影院| 中文字幕人妻色偷偷久久| 久久性精品| 久久婷婷五月综合成人D啪| 久久精品无码一区二区三区| 国产精品久久网| 久久无码人妻一区二区三区| 亚洲va久久久噜噜噜久久| 99久久夜色精品国产网站| 77777亚洲午夜久久多喷| 午夜精品久久久久久99热| 一级做a爰片久久毛片毛片| 一本色道久久综合狠狠躁篇|