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

            Error

            C++博客 首頁 新隨筆 聯系 聚合 管理
              217 Posts :: 61 Stories :: 32 Comments :: 0 Trackbacks

             

            ///////////////////////////////////////////////////////////////////////////////////////////

            實在是沒看出來這樣有什么優勢,為了記錄是否走過某個path?

            Query::execute(const SQLString& str)這里看到了遞歸操作,難道是為了輔助遞歸?

            總感覺這里越搞越復雜,,,

            ///////////////////////////////////////////////////////////////////////////////////////////

            /// \brief A template for setting a flag on a variable as long as the
            /// object that set it is in scope.  Flag resets when object goes
            /// out of scope.  Works on anything that looks like bool.

            template <class T = bool>
            class AutoFlag
            {
            public:
                /// \brief Constructor: sets ref to true.
                AutoFlag(T& ref) :
                referent_(ref)
                {
                    referent_ = true;
                }

                /// \brief Destructor: sets referent passed to ctor to false.
                ~AutoFlag()
                {
                    referent_ = false;
                }

            private:
                T& referent_;
            };

             

            ///////////////////////////////////////////////////////////////////////////////////////////

            ResNSel
            Query::execute(const SQLString& str)
            {
                if ((def.size() == 1) && !def.processing_) {
                    // .  The
                    // auto-reset flag is required because we'll end up back in this
                    // function once the query string is built, but we need to take
                    // the 'else' path to avoid an infinite loop.
                    AutoFlag<> af(def.processing_);
                    return execute(SQLQueryParms() << str);
                }
                else {
                    // Take str to be the entire query string
                    return execute(str.c_str(), str.length());
                }
            }

            ResNSel
            Query::execute(const char* str)
            {
                return execute(SQLString(str));
            }

            ResNSel
            Query::execute(const char* str, size_t len)
            {
                if (lock()) {
                    success_ = false;
                    if (throw_exceptions()) {
                        throw LockFailed();
                    }
                    else {
                        return ResNSel();
                    }
                }

                success_ = !mysql_real_query(&conn_->mysql_, str, len);

                unlock();
                if (success_) {
                    return ResNSel(conn_);
                }
                else if (throw_exceptions()) {
                    throw BadQuery(error());
                }
                else {
                    return ResNSel();
                }
            }

            posted on 2012-10-08 11:51 Enic 閱讀(118) 評論(0)  編輯 收藏 引用
            亚洲嫩草影院久久精品| 国产精品va久久久久久久| 无夜精品久久久久久| 青青草国产97免久久费观看| 久久久这里有精品| 日韩久久久久久中文人妻 | 久久久久久精品成人免费图片| 少妇熟女久久综合网色欲| 色偷偷偷久久伊人大杳蕉| 99久久亚洲综合精品成人| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 精品综合久久久久久88小说| 久久久这里只有精品加勒比| 欧美亚洲国产精品久久蜜芽| 日韩va亚洲va欧美va久久| 2021国产精品久久精品| 超级碰久久免费公开视频| 麻豆成人久久精品二区三区免费 | 中文字幕人妻色偷偷久久| 狠狠色丁香婷婷综合久久来来去| 久久亚洲AV无码精品色午夜 | 久久精品男人影院| 国产精品无码久久综合| 久久精品中文无码资源站| 久久久久久国产精品美女 | 久久99国产精一区二区三区| 国产成年无码久久久免费| 亚洲精品97久久中文字幕无码| 94久久国产乱子伦精品免费| 国产精品福利一区二区久久| 亚洲国产精品无码久久久不卡| 中文字幕无码久久精品青草| 一本大道久久香蕉成人网| 亚洲欧美久久久久9999 | 欧美午夜精品久久久久免费视| 亚洲日本va午夜中文字幕久久 | 99精品国产在热久久无毒不卡| 亚洲精品乱码久久久久久久久久久久| 久久综合九色综合欧美就去吻| 久久性生大片免费观看性| 久久久女人与动物群交毛片 |