首頁 > php框架 > ThinkPHP > ThinkPHP中的fetchSql方法的使用

ThinkPHP中的fetchSql方法的使用

angryTom
發布: 2020-03-28 17:08:43
轉載
3342 人瀏覽過

這篇文章介紹了thinkphp中fetchSql方法的使用,具有一定的參考價值,希望對學習thinkphp的朋友有幫助!

ThinkPHP中的fetchSql方法的使用

ThinkPHP中的fetchSql方法的使用

#前面我們學習了一個sql偵錯的方法getLastSql方法或是別名為_sql ()的方法,但是這個方法要求獲取最後一條成功執行的sql語句,所以如果拿這個方法去調試sql只能夠調試邏輯錯誤,並不能拿來調試語法錯誤,所以在ThinkPHP3.2.3之後新增了一個調試sql的方法:fetchSql();

語法:

$model -> where() -> limit() -> ...->order() -> fetchSql(true) ->CURD操作;
登入後複製

注意:FetchSql方法使用的時候可以完全看作是輔助方法,所以要求必須在model之後,在CURD操作之前,順序無所謂。 FetchSql方法只能在ThinkPHP3.2.3版本之後使用。

ThinkPHP中的fetchSql方法的使用

如圖為ThinkPHP3.2.3先前版本的手冊

去控制器測試:

    //fetchSql方法
    public function test(){
        //实例化模型
        $model = M('Dept');
        //fetchSql方法
        $result = $model -> group('name') -> field('name,count(*)') -> fetchSql(true) -> select();
        //打印
        dump($result);
    }
登入後複製

顯示結果:

ThinkPHP中的fetchSql方法的使用

sql追蹤訊息中的結果:

ThinkPHP中的fetchSql方法的使用

#當sql語句錯誤時:

    //fetchSql方法
    public function test(){
        //实例化模型
        $model = M('Dept');
        //fetchSql方法
        $result = $model -> group('name') -> field('name,count(*,,,,,,,//)') -> fetchSql(true) -> select();
        //打印
        dump($result);
    }
登入後複製

顯示結果:

ThinkPHP中的fetchSql方法的使用

sql追蹤資訊中的結果:

ThinkPHP中的fetchSql方法的使用

#說明:透過追蹤資訊和傳回值,我們可以發現,使用fetchSql之後原有的連貫操作沒有被執行,而是直接將連貫操作的語法組成的sql語句給回傳。

(推薦教學:thinkphp教學

以上是ThinkPHP中的fetchSql方法的使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板