• <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)  編輯 收藏 引用
            国内精品久久久久久麻豆| 亚洲午夜久久久久久久久电影网 | 青青青青久久精品国产h久久精品五福影院1421| 狠狠色婷婷综合天天久久丁香 | 国产精品午夜久久| 欧美精品丝袜久久久中文字幕 | 99精品国产综合久久久久五月天| 久久久久久精品无码人妻| 精品久久人妻av中文字幕| 国产成人精品久久综合| 亚洲精品国产综合久久一线| 无码AV波多野结衣久久| 久久精品亚洲乱码伦伦中文| 97久久国产露脸精品国产| 伊人久久大香线蕉影院95| 久久久久久精品免费看SSS| 久久精品国产99国产电影网| 国产成人精品三上悠亚久久| 成人精品一区二区久久久| 亚洲国产一成人久久精品| 无码乱码观看精品久久| 国产精品久久久亚洲| 国产A级毛片久久久精品毛片| 久久精品免费网站网| 国产99久久久久久免费看| 久久99久久99精品免视看动漫| 国产免费久久精品99re丫y| 超级碰久久免费公开视频| 国产精品久久久久久| 人妻精品久久无码区| 久久久久久久久久久| 久久无码精品一区二区三区| 久久99免费视频| 精品国产一区二区三区久久久狼| 狠狠色丁香婷婷久久综合五月| 国产精品VIDEOSSEX久久发布| 国产产无码乱码精品久久鸭| 国产精品99久久久精品无码| 亚洲欧美国产精品专区久久| 久久久久婷婷| 午夜精品久久久久久久无码|