## 創建core/database/query/QueryBuilder.php
```
<?php
namespace core\database\query;
use core\database\connection\Connection;
class QueryBuilder
{
protected $connection;
protected $grammar;
public $binds;
public $columns;
public $distinct;
public $form;
public $union;
public $bindings = [
'select' => [],
'from' => [],
'join' => [],
'where' => [],
'groupBy' => [],
'having' => [],
'order' => [],
'union' => [],
'unionOrder' => [],
];
protected $operators = [
'=','<','>','<=','>=','<>','!=','<=>','like','like binary','not like','ilike','&','|','^',
'<<','>>','rlike','not rlike','regexp','not regexp','~','~*','!~','!~*','similar to','not similar to',
'not ilike','~~*','!~~*'
];
public function __construct(Connection $connection, $grammar)
{
$this->connection = $connection; // 數據庫連接
$this->grammar = $grammar; // 編譯成sql的類
}
public function table(string $table,$as = null)
{
return $this->from($table,$as);
// return (clone $this)->from($table,$as);
}
public function from($table,$as)
{
$this->from = $as ? "{$table} as {$as}" : $table;
return $this;
}
public function get($columns = ['*'])
{
if(! is_array($columns))
$columns = func_get_args();
$this->columns = $columns;
$sql = $this->toSql();
return $this->runSql($sql);
}
// 運行sql
public function runSql($sql)
{
return $this->connection->select(
$sql,$this->getBinds()
);
}
public function where($column, $operator = null, $value = null, $joiner = 'and')
{
if ( is_array($column)) // 如果是 where(['id' => '2','name' => 'xxh']) 這種
foreach ($column as $col => $value)
$this->where($col,'=',$value);
if(! in_array($operator,$this->operators)){ // 操作符不存在
$value = $operator;
$operator = '=';
}
$type = 'Basic';
$this->wheres[] = compact(
'type', 'column', 'operator', 'value', 'joiner'
); // 存到wheres變量
$this->binds[] = $value;
return $this;
}
public function orWhere($column, $operator = null, $value = null)
{
return $this->where($column, $operator, $value ,'or');
}
public function find($id,$columns = ['*'],$key = 'id')
{
return $this->where($key,$id)->get($columns);
}
public function whereLike($column, $operator = null, $value = null)
{
return $this->where($column, $operator, $value, 'like');
}
public function toSql() // 編譯成sql
{
return $this->grammar->compileSql($this);
}
public function getBinds() // 綁定
{
return $this->binds;
}
}
```
## 創建core/database/query/MysqlGrammar
```
<?php
namespace core\database\query;
class MysqlGrammar
{
protected $selectComponents = [
'columns',
'from',
'joins',
'wheres',
'groups',
'havings',
'orders',
'limit',
'offset',
'lock',
];
public function compileSql(QueryBuilder $query)
{
$sql = [];
foreach ($this->selectComponents as $component)
if( isset( $query->{$component}))
$sql[$component] = $this->$component($query, $query->$component);
return implode($sql);
}
protected function columns(QueryBuilder $query,$columns)
{
if(! $columns)
$columns = ['*'];
$select = 'select ';
if ($query->distinct)
$select = 'select distinct ';
return $select . implode(',',$columns);
}
protected function from(QueryBuilder $query,$form)
{
return ' from '.$form;
}
protected function joins()
{
}
protected function wheres(QueryBuilder $queryBuilder,$wheres)
{
if(! $wheres)
return '';
$where_arrs = [];
foreach ($wheres as $index => $where){
if(! $index)
$where['joiner'] = ' where';
$where_arrs[] = sprintf(' %s `%s` %s ?',$where['joiner'], $where['column'], $where['operator']);
}
return implode($where_arrs);
}
protected function groups()
{
}
protected function havings()
{
}
protected function orders()
{
}
protected function limit()
{
}
protected function offset()
{
}
protected function lock()
{
}
}
```
## 編輯core\database\connection\MysqlConnection.php
添加以下代碼
```
// 調用不存在的方法 調用一個新的查詢構造器
public function __call($method, $parameters)
{
// 返回QueryBuilder類
return $this->newBuilder()->$method(...$parameters);
}
// 創建新的查詢器
public function newBuilder()
{
return new QueryBuilder($this, new MysqlGrammar());
}
````

## 運行


- 前言
- 基礎篇
- 1. 第一步 創建框架目錄結構
- 2. 引入composer自動加載
- 3. php自動加載 (解釋篇)
- 4. 創建容器 注冊樹模式
- 5. 關于psr規范解釋
- 6. 關于"容器" "契約" "依賴注入" (解釋篇)
- 7. 添加函數文件helpers.php
- 8. 初始化請求(Request)
- 9. 響應 (Response)
- 10. 路由一 (路由組實現)
- 11. 路由二 (加入中間件)
- 12. 配置信息 (類似laravel)
- 13. 數據庫連接 (多例模式)
- 14. 查詢構造器 (query builder)
- MVC實現
- M 模型實現 (數據映射 + 原型 模式)
- C 控制器實現 + 控制器中間件
- V 視圖實現 (Laravel Blade 引擎)
- V 視圖切換成 ThinkPhp 模板 引擎)
- 其他輪子
- 日志
- 自定義異常 (異常托管)
- 單元測試 (phpunit)
- 替換成swoole的http服務器
- 協程上下文解決request問題
- qps測試
- 發布到packagist.org