## 查詢構造器
除了原生查詢外,5.0還提供了數據庫查詢構造器,可以更方便執行數據庫操作,查詢構造器基于PDO實現,對不同的數據庫驅動都是統一的語法。
>[danger]#### 注意:
> * * * * *
> ThinkPHP `5.0`查詢構造器使用 `PDO `參數綁定,以保護應用程序免于 `SQL`注入,因此傳入的參數不需額外轉義特殊字符。
同樣是實現上面的功能,我們可以改成:
~~~
// 插入記錄
Db::table('think_data')
->insert(['id' => 18, 'name' => 'thinkphp', 'status' => 1]);
// 更新記錄
Db::table('think_data')
->where('id', 18)
->update(['name' => "hello"]);
// 查詢數據
$list = Db::table('think_data')
->field('name,email')
->where('id', 18)
->select();
// 刪除數據
Db::table('think_data')
->where('id', 18)
->delete();
~~~
由于我們在數據庫配置文件中設置了數據表的前綴為`think_`,因此,`table`方法可以改成`name`方法,這樣就不會因為數據表前綴的修改而改動`CURD`代碼,例如:
~~~
// 插入記錄
Db::name('data')
->insert(['id' => 18, 'name' => 'thinkphp']);
// 更新記錄
Db::name('data')
->where('id', 18)
->update(['name' => "framework"]);
// 查詢數據
$list = Db::name('data')
->where('id', 18)
->select();
dump($list);
// 刪除數據
Db::name('data')
->where('id', 18)
->delete();
~~~
如果使用系統提供的助手函數`db`則可以進一步簡化查詢代碼如下:
~~~
$db = db('data');
// 插入記錄
$db->insert(['id' => 20, 'name' => 'thinkphp']);
// 更新記錄
$db->where('id', 20)->update(['name' => "framework"]);
// 查詢數據
$list = $db->where('id', 20)->select();
dump($list);
// 刪除數據
$db->where('id', 20)->delete();
~~~
>[danger] `db`助手函數在`V5.0.9`之前版本默認會每次重新連接數據庫,因此應當盡量避免多次調用。
關于更多的查詢條件和查詢語法,會在后面一章查詢語言中詳細講述。
- 零、序言
- 一、基礎
- (1)簡介
- (2)安裝
- (3)目錄結構
- (4)運行環境
- (5)入口文件
- (6)資源訪問
- (7)調試模式
- (8)控制器
- (9)視圖
- (10)讀取數據
- (11)總結
- 二、URL和路由
- (1)URL訪問
- (2)參數傳入
- (3)隱藏入口
- (4)定義路由
- (5)URL生成
- (6)總結
- 三、請求和響應
- (1)請求對象
- (2)請求信息
- (3)響應對象
- (4)總結
- 四、數據庫
- (1)準備
- (2)數據庫配置
- (3)原生查詢
- (4)查詢構造器
- (5)鏈式操作
- (6)事務支持
- 五、查詢語言
- (1)查詢表達式
- (2)批量查詢
- (3)快捷查詢
- (4)視圖查詢
- (5)閉包查詢
- (6)獲取值和列
- (7)聚合查詢
- (8)時間查詢
- (9)字符串查詢
- (10)分塊查詢
- 六、模型和關聯
- (1)模型定義
- (2)基礎操作
- (3)讀取器和修改器
- (4)類型轉換和自動完成
- (5)查詢范圍
- (6)輸入和驗證
- (7)關聯
- (8)模型輸出
- 七、視圖和模板
- (1)模板輸出
- (2)分頁輸出
- (3)公共模板
- (4)模板定位
- (5)布局模板
- (6)標簽定制
- (7)輸出替換
- (8)渲染內容
- (9)助手函數
- 八、調試和日志
- (1)第一式:未雨綢繆——頁面Trace
- (2)第二式:初見端倪——異常頁面
- (3)第三式:撥云見日——斷點調試
- (4)第四式:欲窮千里——日志分析
- (5)第五式:運籌帷幄——遠程調試
- 九、API開發
- (1)API版本
- (2)異常處理
- (3)RESTFul
- (4)REST調試
- (5)API調試
- (6)安全建議
- 十、命令行工具
- (1)查看指令
- (2)模塊生成
- (3)控制器生成
- (4)生成類庫映射文件
- (5)生成路由緩存
- (6)生成字段緩存
- (7)指令擴展
- (8)命令行調試
- (9)命令行顏色支持
- (10)命令調用
- 十一、擴展
- (1)函數擴展
- (2)類庫擴展
- (3)驅動擴展
- (4)Composer擴展
- 十二、雜項
- Session
- Cookie
- 驗證碼
- 文件上傳
- 圖像處理
- 單元測試
- 番外篇:學習ThinkPHP5的正確姿勢
- 概念篇:ThinkPHP5名詞解釋
- 附錄A、常見問題集
- 附錄B、3.2和5.0區別
- 附錄C、助手函數
- 附錄D、5.1你必須努力避免的一些問題