# 函數原型
~~~
public function join($mixTable, $mixCols = '*', $mixCond /* args */);
~~~
# $mixTable 和 $mixCols 與 table 方法中的用法一致
~~~
# SELECT `test`.*,`hello`.`name`,`hello`.`value` FROM `test` INNER JOIN `hello` ON `test`.`name` = '小牛'
database::table ( 'test')->join('hello','name,value', 'name','=','小牛' )->getAll ();
# SELECT `test`.*,`t`.`name` AS `nikename`,`t`.`value` AS `tt` FROM `test` INNER JOIN `hello` `t` ON `test`.`name` = '小牛'
database::table ( 'test')->join(['t' => 'hello'],['name as nikename','tt' => 'value'], 'name','=','小牛' )->getAll ();
~~~
# $mixCond 與 where 方法中的用法一致
去掉前面兩個參數,后面的全部都是條件參數。
~~~
# SELECT `test`.*,`hello`.`name`,`hello`.`value` FROM `test` INNER JOIN `hello` ON `test`.`hello` = 'world' AND `test`.`test` > `test`.`name`
database::table ( 'test')->join('hello','name,value', ['hello' => 'world',['test','>','{[name]}']] )->getAll ();
# SELECT `test`.*,`hello`.`name`,`hello`.`value` FROM `test` INNER JOIN `hello` ON (`hello`.`id` < 5 AND `hello`.`name` LIKE 'hello')
database::table ( 'test')->join('hello','name,value', function($objSelect){
$objSelect->where('id','<',5)->where('name','like','hello');
} )->getAll ();
~~~
# innerJoin 與 join 一致
~~~
# SELECT `test`.*,`t`.`name` AS `nikename`,`t`.`value` AS `tt` FROM `test` INNER JOIN `hello` `t` ON `t`.`name` = '小牛'
database::table ( 'test')->innerJoin(['t' => 'hello'],['name as nikename','tt' => 'value'], 'name','=','小牛' )->getAll ();
~~~
# leftJoin
~~~
# SELECT `test`.*,`t`.`name` AS `nikename`,`t`.`value` AS `tt` FROM `test` LEFT JOIN `hello` `t` ON `t`.`name` = '小牛'
database::table ( 'test')->innerJoin(['t' => 'hello'],['name as nikename','tt' => 'value'], 'name','=','小牛' )->getAll ();
~~~
# rightJoin
~~~
# SELECT `test`.*,`t`.`name` AS `nikename`,`t`.`value` AS `tt` FROM `test` RIGHT JOIN `hello` `t` ON `t`.`name` = '小牛'
database::table ( 'test')->rightJoin(['t' => 'hello'],['name as nikename','tt' => 'value'], 'name','=','小牛' )->getAll ();
~~~
# fullJoin
~~~
# SELECT `test`.*,`t`.`name` AS `nikename`,`t`.`value` AS `tt` FROM `test` FULL JOIN `hello` `t` ON `t`.`name` = '小牛'
database::table ( 'test')->fullJoin(['t' => 'hello'],['name as nikename','tt' => 'value'], 'name','=','小牛' )->getAll ();
~~~
# crossJoin
交叉連接不用設置 on 條件。
~~~
# SELECT `test`.*,`t`.`name` AS `nikename`,`t`.`value` AS `tt` FROM `test` CROSS JOIN `hello` `t`
database::table ( 'test')->crossJoin(['t' => 'hello'],['name as nikename','tt' => 'value'] )->getAll ();
~~~
# naturalJoin
自然連接不用設置 on 條件。
~~~
# SELECT `test`.*,`t`.`name` AS `nikename`,`t`.`value` AS `tt` FROM `test` NATURAL JOIN `hello` `t`
database::table ( 'test')->naturalJoin(['t' => 'hello'],['name as nikename','tt' => 'value'] )->getAll ();
~~~
- 關于 QueryPHP
- 獲取 QueryPHP
- 環境要求
- 許可協議 Free
- 執行流程 MVC
- 命名規范 $sName
- 目錄結構 DIR
- 單一入口 index.php
- 響應客戶端請求 URL
- 命名空間與自動載入 Autoload
- 路由
- 路由導入
- 批量導入
- 參數正則
- 分組定義
- 路由綁定
- 路由域名
- 分層控制器
- 默認和初始化APP
- 默認控制器和方法
- url 模式
- url 生成
- url 偽靜態
- url 重寫
- url 重定向
- 控制器綁定
- 方法器分層
- 控制器 __init
- 控制器方法交互
- 模板引擎語法
- C變量輸出 $sName
- C變量支持函數和方法 $sName|trim
- C快捷輸出 ~
- C標簽簡化 Css & Javascript
- C默認值 eq 三元運算符
- C變量運算符 +-
- 變量遞增遞減 ++--
- C循環數據 list
- N變量賦值 assign
- N循環數據 list
- N循環數據高級版 lists
- C循環數據 while
- N循環數據 while
- C循環數據 for
- N循環數據 for
- C條件判斷 if
- N條件判斷 if
- 標簽嵌套無限層級
- N循環流程 break & continue
- N使用 PHP 代碼
- N包含子模板 include
- J模板引擎 intro
- J條件判斷 if
- J循環數據 each
- J變量 & 表達式
- J變量支持函數和方法 hello|test
- J默認值 eq 三元運算符
- J框架前端組件 jquery.queryphp.js
- J前端 CSS 規范
- J前端 JS 規范
- 保護標簽自身 tagself
- 數據庫
- 數據庫配置
- 執行原生 sql 語句
- 數據庫事務
- 數據庫構造器 prefix
- 數據庫構造器 table
- 數據庫構造器 forceIndex
- 數據庫構造器 where
- 數據庫構造器 bind
- 數據庫構造器 join
- 數據庫構造器 union
- 數據庫構造器 orderBy
- 數據庫構造器 groupBy
- 數據庫構造器 having
- 數據庫構造器 distinct
- 數據庫構造器 aggregate
- 數據庫構造器 limit
- 數據庫構造器 forUpdate
- 數據庫構造器 columns
- 數據庫構造器 reset
- 數據庫集合查詢
- 數據庫查詢數據 get
- 數據庫查詢多條數據 getAll
- 數據庫查詢單條數據 getOne
- 數據庫查詢聚合查詢 aggregate
- 數據庫寫入數據 insert
- 數據庫寫入數據 insertAll
- 配置
- 配置格式
- 慣性配置
- 配置文件
- 讀取配置
- 設置配置
- 刪除配置
- 日志
- 日志配置參數
- 日志路徑
- 日志過濾器
- 日志處理器
- 緩存
- 緩存配置參數
- 緩存路徑
- 緩存指定時間
- COOKIE
- COOKIE 配置參數
- 開發調試
- 頁面 trace