CodeIgniter4 查詢(xún)構(gòu)造器類(lèi)

2020-08-17 16:18 更新

CodeIgniter 提供了查詢(xún)構(gòu)造器類(lèi),它允許你用較少的代碼量獲取數(shù)據(jù)庫(kù)的信息、新增 或更新數(shù)據(jù)。有時(shí)只需要一兩行代碼就能完成數(shù)據(jù)庫(kù)操作。CodeIgniter 不要求每個(gè)數(shù)據(jù)表 有一個(gè)類(lèi)文件,它使用了一種更簡(jiǎn)單的接口。

除了簡(jiǎn)單,使用查詢(xún)構(gòu)造器的主要好處是可以讓你創(chuàng)建跨數(shù)據(jù)庫(kù)的應(yīng)用程序,因?yàn)椴樵?xún)語(yǔ)句 是由每種數(shù)據(jù)庫(kù)適配器生成的。它也允許用于更安全的查詢(xún),因?yàn)橄到y(tǒng)會(huì)自動(dòng)轉(zhuǎn)義傳入數(shù)據(jù)。

加載查詢(xún)構(gòu)造器

查詢(xún)構(gòu)造器通過(guò)數(shù)據(jù)庫(kù)連接對(duì)象的 table() 方法加載, 這會(huì)設(shè)置查詢(xún)語(yǔ)句 FROM 的部分并且返回一個(gè)查詢(xún)構(gòu)造器的新實(shí)例:

$db      = \Config\Database::connect();
$builder = $db->table('users');

查詢(xún)構(gòu)造器僅在你明確請(qǐng)求類(lèi)時(shí)才加載到內(nèi)存中,因此默認(rèn)不使用(消耗)任何資源。

選擇數(shù)據(jù)

下面的方法用來(lái)構(gòu)建 SQL SELECT 語(yǔ)句。

$builder->get()

執(zhí)行選擇查詢(xún)并返回結(jié)果,可用于獲取一個(gè)表的所有記錄:

$builder = $db->table('mytable');
$query   = $builder->get();  // 生成: SELECT * FROM mytable

第一個(gè)和第二個(gè)參數(shù)用于設(shè)置 limit 和 offset 子句:

$query = $builder->get(10, 20);


// 執(zhí)行: SELECT * FROM mytable LIMIT 20, 10
// (在 MySQL 里的情況,其他數(shù)據(jù)庫(kù)的語(yǔ)法略有不同)

你應(yīng)該已經(jīng)注意到了,上面方法的結(jié)果賦值給了一個(gè) $query 變量, 我們可以用它輸出查詢(xún)結(jié)果:

$query = $builder->get();


foreach ($query->getResult() as $row)
{
        echo $row->title;
}

請(qǐng)?jiān)L問(wèn) 結(jié)果方法 頁(yè)面獲得結(jié)果生成的完整論述。

$builder->getCompiledSelect()

$builder->get() 方法一樣編譯選擇查詢(xún)但是并不執(zhí)行, 此方法只是將 SQL 查詢(xún)語(yǔ)句作為字符串返回。

例如:

$sql = $builder->getCompiledSelect();
echo $sql;


// 輸出字符串: SELECT * FROM mytable

第一個(gè)參數(shù)使你能設(shè)置是否重置查詢(xún)構(gòu)造器(默認(rèn)重置, 就像使用 $builder->get() 時(shí)一樣):

echo $builder->limit(10,20)->getCompiledSelect(false);


// 輸出字符串: SELECT * FROM mytable LIMIT 20, 10
// (在 MySQL 里的情況,其他數(shù)據(jù)庫(kù)的語(yǔ)法略有不同)


echo $builder->select('title, content, date')->getCompiledSelect();


// 輸出字符串: SELECT title, content, date FROM mytable LIMIT 20, 10

最值得注意的是,上例第二個(gè)查詢(xún)并沒(méi)有用到 $builder->from() 方法, 也沒(méi)有為查詢(xún)指定表名參數(shù)。因?yàn)檫@個(gè)查詢(xún)沒(méi)有被可重置值的 $builder->get() 方法執(zhí)行,或是使用 $builder->resetQuery() 方法直接重置。

$builder->getWhere()

get() 函數(shù)相同,只是它允許你用第一個(gè)參數(shù)中添加 “where” 子句, 而不是使用 db->where() 功能:

$query = $builder->getWhere(['id' => $id], $limit, $offset);

請(qǐng)閱讀下面 where 方法獲得更多信息。

$builder->select()

允許你編寫(xiě)查詢(xún)的 SELECT 部分:

$builder->select('title, content, date');
$query = $builder->get();


// 執(zhí)行: SELECT title, content, date FROM mytable

注解

如果要從表中選擇全部字段 () ,不需要使用這個(gè)函數(shù)。 當(dāng)省略它時(shí),CodeIgniter 假定你希望選擇所有字段并自動(dòng)添加 ‘SELECT ’ 。

$builder->select() 方法的第二個(gè)參數(shù)可選,如果設(shè)置為 FALSE, CodeIgniter 將不保護(hù)你的表名和字段名。當(dāng)你編寫(xiě)復(fù)合查詢(xún)語(yǔ)句時(shí)很有用, 它不會(huì)因?yàn)樽詣?dòng)轉(zhuǎn)義而搞壞你的語(yǔ)句。

$builder->select('(SELECT SUM(payments.amount) FROM payments WHERE payments.invoice_id=4) AS amount_paid', FALSE);
$query = $builder->get();

$builder->selectMax()

該方法用于編寫(xiě)查詢(xún)語(yǔ)句中的 SELECT MAX(field) 部分, 你可以使用第二個(gè)參數(shù)重命名結(jié)果字段(可選)。

$builder->selectMax('age');
$query = $builder->get();  // 生成: SELECT MAX(age) as age FROM mytable


$builder->selectMax('age', 'member_age');
$query = $builder->get(); // 生成: SELECT MAX(age) as member_age FROM mytable

$builder->selectMin()

該方法用于編寫(xiě)查詢(xún)語(yǔ)句中的 “SELECT MIN(field)” 部分, 和 selectMax() 一樣,你可以使用第二個(gè)參數(shù)重命名結(jié)果字段(可選)。

$builder->selectMin('age');
$query = $builder->get(); // 生成: SELECT MIN(age) as age FROM mytable

$builder->selectAvg()

該方法用于編寫(xiě)查詢(xún)語(yǔ)句中的 “SELECT AVG(field)” 部分, 和 selectMax() 一樣,你可以使用第二個(gè)參數(shù)重命名結(jié)果字段(可選)。

$builder->selectAvg('age');
$query = $builder->get(); // 生成: SELECT AVG(age) as age FROM mytable

$builder->selectSum()

該方法用于編寫(xiě)查詢(xún)語(yǔ)句中的 “SELECT SUM(field)” 部分, 和 selectMax() 一樣,你可以使用第二個(gè)參數(shù)重命名結(jié)果字段(可選)。

$builder->selectSum('age');
$query = $builder->get(); // 生成: SELECT SUM(age) as age FROM mytable

$builder->selectCount()

該方法用于編寫(xiě)查詢(xún)語(yǔ)句中的 “SELECT COUNT(field)” 部分, 和 selectMax() 一樣,你可以使用第二個(gè)參數(shù)重命名結(jié)果字段(可選)。

注解

該方法在使用 groupBy() 時(shí)特別有用。 用于一般的結(jié)果計(jì)數(shù)詳見(jiàn) countAll()countAllResults()

$builder->selectCount('age');
$query = $builder->get(); // 生成: SELECT COUNT(age) as age FROM mytable

$builder->from()

該方法用于編寫(xiě)查詢(xún)語(yǔ)句中的 FROM 子句:

$builder->select('title, content, date');
$builder->from('mytable');
$query = $builder->get();  // 生成: SELECT title, content, date FROM mytable

注解

正如前面所說(shuō),查詢(xún)中的 FROM 部分可以在方法 $db-&table() 中指定。 額外調(diào)用 from() 將向查詢(xún)的 FROM 部分添加更多表。

$builder->join()

該方法用于編寫(xiě)查詢(xún)語(yǔ)句中的 JOIN 子句:

$builder->db->table('blog');
$builder->select('*');
$builder->join('comments', 'comments.id = blogs.id');
$query = $builder->get();


// 生成:
// SELECT * FROM blogs JOIN comments ON comments.id = blogs.id

如果你的查詢(xún)有多個(gè)連接,可以多次調(diào)用這個(gè)方法。

你可以傳入第三個(gè)參數(shù)指定連接的類(lèi)型,可選: left,right, outer, inner, left outer 和 right outer 。

$builder->join('comments', 'comments.id = blogs.id', 'left');
// 生成: LEFT JOIN comments ON comments.id = blogs.id

查找具體數(shù)據(jù)

$builder->where()

該方法提供了4中方式讓你編寫(xiě)查詢(xún)語(yǔ)句中的 WHERE 子句:

注解

所有傳入數(shù)據(jù)將會(huì)自動(dòng)轉(zhuǎn)義,生成安全的查詢(xún)語(yǔ)句。

  1. 簡(jiǎn)單的 key/value 方式:

   $builder->where('name', $name); // 生成: WHERE name = 'Joe'

注意它自動(dòng)為你加上了等號(hào)。

如果你多次調(diào)用該方法,那么多個(gè) WHERE 條件將會(huì)使用 AND 連接:

   $builder->where('name', $name);
   $builder->where('title', $title);
   $builder->where('status', $status);
   // WHERE name = 'Joe' AND title = 'boss' AND status = 'active'

  1. 自定義 key/value 方式:

你可以在第一個(gè)參數(shù)中包含一個(gè)比較運(yùn)算符,用來(lái)控制比較條件:

   $builder->where('name !=', $name);
   $builder->where('id <', $id); // 生成: WHERE name != 'Joe' AND id < 45

  1. 關(guān)聯(lián)數(shù)組方式:

   $array = ['name' => $name, 'title' => $title, 'status' => $status];
   $builder->where($array);
   // 生成: WHERE name = 'Joe' AND title = 'boss' AND status = 'active'

你也可以在這個(gè)方法里包含你自己的運(yùn)算符:

   $array = ['name !=' => $name, 'id <' => $id, 'date >' => $date];
   $builder->where($array);

  1. 自定義字符串:

你可以手動(dòng)編寫(xiě)子句:

     $where = "name='Joe' AND status='boss' OR status='active'";
     $builder->where($where);

$builder->where() 的第三個(gè)參數(shù)(可選),如果設(shè)置為 FALSE,CodeIgniter 將不保護(hù)你的表名和字段名。

$builder->where('MATCH (field) AGAINST ("value")', NULL, FALSE);

  1. 子查詢(xún):

你可以使用匿名函數(shù)生成一個(gè)子查詢(xún)。

     $builder->where('advance_amount <', function(BaseBuilder $builder) {
         return $builder->select('MAX(advance_amount)', false)->from('orders')->where('id >', 2);
     });
     // 生成: WHERE "advance_amount" < (SELECT MAX(advance_amount) FROM "orders" WHERE "id" > 2) 

$builder->orWhere()

這個(gè)方法和上面的方法一樣,只是多個(gè)條件之間使用 OR 進(jìn)行連接

$builder->where('name !=', $name);
$builder->orWhere('id >', $id);  // 生成: WHERE name != 'Joe' OR id > 50

$builder->whereIn()

該方法用于生成 WHERE IN(‘item’, ‘item’) 子句,多個(gè)子句之間使用 AND 連接

$names = ['Frank', 'Todd', 'James'];
$builder->whereIn('username', $names);
// 生成: WHERE username IN ('Frank', 'Todd', 'James')

你可以用子查詢(xún)替代數(shù)組值。

$builder->whereIn('id', function(BaseBuilder $builder) {
    return $builder->select('job_id')->from('users_jobs')-where('user_id', 3);
});
// 生成: WHERE "id" IN (SELECT "job_id" FROM "users_jobs" WHERE "user_id" = 3)

$builder->orWhereIn()

該方法用于生成 WHERE IN(‘item’, ‘item’) 子句,多個(gè)子句之間使用 OR 連接

$names = ['Frank', 'Todd', 'James'];
$builder->orWhereIn('username', $names);
// 生成: OR username IN ('Frank', 'Todd', 'James')

你可以用子查詢(xún)替代數(shù)組值。

$builder->orWhereIn('id', function(BaseBuilder $builder) {
    return $builder->select('job_id')->from('users_jobs')->where('user_id', 3);
});


// 生成: OR "id" IN (SELECT "job_id" FROM "users_jobs" WHERE "user_id" = 3)

$builder->whereNotIn()

該方法用于生成 WHERE NOT IN(‘item’, ‘item’) 子句,多個(gè)子句之間使用 AND 連接

$names = ['Frank', 'Todd', 'James'];
$builder->whereNotIn('username', $names);
// 生成: WHERE username NOT IN ('Frank', 'Todd', 'James')

你可以用子查詢(xún)替代數(shù)組值。

$builder->whereNotIn('id', function(BaseBuilder $builder) {
    return $builder->select('job_id')->from('users_jobs')->where('user_id', 3);
});


// 生成: WHERE "id" NOT IN (SELECT "job_id" FROM "users_jobs" WHERE "user_id" = 3)

$builder->orWhereNotIn()

該方法用于生成 WHERE NOT IN(‘item’, ‘item’) 子句,多個(gè)子句之間使用 OR 連接

$names = ['Frank', 'Todd', 'James'];
$builder->orWhereNotIn('username', $names);
// 生成: OR username NOT IN ('Frank', 'Todd', 'James')

你可以用子查詢(xún)替代數(shù)組值。

$builder->orWhereNotIn('id', function(BaseBuilder $builder) {
    return $builder->select('job_id')->from('users_jobs')->where('user_id', 3);
});


// 生成: OR "id" NOT IN (SELECT "job_id" FROM "users_jobs" WHERE "user_id" = 3)

查找相似的數(shù)據(jù)

$builder->like()

這個(gè)方法使您能夠生成類(lèi)似 LIKE 子句,做搜索時(shí)非常有用。

注解

所有傳入數(shù)據(jù)將被自動(dòng)轉(zhuǎn)義。

like* 通過(guò)傳第五個(gè)參數(shù)傳遞值 true 可以強(qiáng)制在 執(zhí)行查詢(xún)時(shí)不區(qū)分大小寫(xiě)。這項(xiàng)特性可用性跟平臺(tái)相關(guān),否則將強(qiáng)制值轉(zhuǎn)為小寫(xiě), 例如 WHERE LOWER(column) LIKE '%search%',讓其生效可能需要 在制作索引時(shí)用 LOWER(column) 而不是 column 。

  1. 簡(jiǎn)單 key/value 方式:

   $builder->like('title', 'match');
   // 生成: WHERE `title` LIKE '%match%' ESCAPE '!'

如果你多次調(diào)用該方法,那么多個(gè) WHERE 條件將會(huì)使用 AND 連接起來(lái):

   $builder->like('title', 'match');
   $builder->like('body', 'match');
   // WHERE `title` LIKE '%match%' ESCAPE '!' AND  `body` LIKE '%match% ESCAPE '!'

如果你想控制通配符通配符(%)的位置,可以指定第三個(gè)參數(shù), 可用選項(xiàng):’before’,’after’ 和 ‘both’ (默認(rèn)) 。

   $builder->like('title', 'match', 'before');     // 生成: WHERE `title` LIKE '%match' ESCAPE '!'
   $builder->like('title', 'match', 'after');      // 生成: WHERE `title` LIKE 'match%' ESCAPE '!'
   $builder->like('title', 'match', 'both');       // 生成: WHERE `title` LIKE '%match%' ESCAPE '!'

  1. 關(guān)聯(lián)數(shù)組方式:

   $array = ['title' => $match, 'page1' => $match, 'page2' => $match];
   $builder->like($array);
   // WHERE `title` LIKE '%match%' ESCAPE '!' AND  `page1` LIKE '%match%' ESCAPE '!' AND  `page2` LIKE '%match%' ESCAPE '!'

$builder->orLike()

這個(gè)方法和上面的方法一樣,只是多個(gè) WHERE 條件之間使用 OR 進(jìn)行連接:

$builder->like('title', 'match'); $builder->orLike('body', $match);
// WHERE `title` LIKE '%match%' ESCAPE '!' OR  `body` LIKE '%match%' ESCAPE '!'

$builder->notLike()

這個(gè)方法和 like() 方法一樣,只是生成 NOT LIKE 子句:

$builder->notLike('title', 'match');    // WHERE `title` NOT LIKE '%match% ESCAPE '!'

$builder->orNotLike()

這個(gè)方法和 notLike() 方法一樣,只是多個(gè)條件之間使用 OR 連接:

$builder->like('title', 'match');
$builder->orNotLike('body', 'match');
// WHERE `title` LIKE '%match% OR  `body` NOT LIKE '%match%' ESCAPE '!'

$builder->groupBy()

該方法用于生成 GROUP BY 子句:

$builder->groupBy("title"); // 生成: GROUP BY title

你也可以通過(guò)一個(gè)數(shù)組傳入多個(gè)值:

$builder->groupBy(["title", "date"]);  // 生成: GROUP BY title, date

$builder->distinct()

該方法用于向查詢(xún)中添加 “DISTINCT” 關(guān)鍵字

$builder->distinct();
$builder->get(); // 生成: SELECT DISTINCT * FROM mytable

$builder->having()

該方法用于生成 HAVING 子句,有下面兩種不同的語(yǔ)法。 有兩種可用語(yǔ)法,單參數(shù)或雙參數(shù):

$builder->having('user_id = 45');  // 生成: HAVING user_id = 45
$builder->having('user_id',  45);  // 生成: HAVING user_id = 45

你還可以傳遞一個(gè)包含多個(gè)值的數(shù)組:

$builder->having(['title =' => 'My Title', 'id <' => $id]);
// 生成: HAVING title = 'My Title', id < 45

如果你正在使用 CodeIgniter 為其轉(zhuǎn)義查詢(xún)的數(shù)據(jù)庫(kù), 你可以傳第三個(gè)可選參數(shù)來(lái)防止轉(zhuǎn)義內(nèi)容,設(shè)為 FALSE 。

$builder->having('user_id',  45);  // 生成: HAVING `user_id` = 45 in some databases such as MySQL
$builder->having('user_id',  45, FALSE);  // 生成: HAVING user_id = 45

$builder->orHaving()

該方法和 having() 方法一樣,只是多個(gè)條件之間使用 “OR” 進(jìn)行連接。

$builder->havingIn()

生成一個(gè) HAVING 字段的 IN (‘item’, ‘item’) SQL 查詢(xún)子句, 多個(gè)條件之間使用 AND 連接

$groups = [1, 2, 3];
$builder->havingIn('group_id', $groups);
// 生成: HAVING group_id IN (1, 2, 3)

你可以用子查詢(xún)代替數(shù)組。

$builder->havingIn('id', function(BaseBuilder $builder) {
    return $builder->select('user_id')->from('users_jobs')->where('group_id', 3);
});
// 生成: HAVING "id" IN (SELECT "user_id" FROM "users_jobs" WHERE "group_id" = 3)

$builder->orHavingIn()

生成一個(gè) HAVING 字段的 IN (‘item’, ‘item’) SQL 查詢(xún)子句, 多個(gè)條件之間使用 OR 連接

$groups = [1, 2, 3];
$builder->orHavingIn('group_id', $groups);
// 生成: OR group_id IN (1, 2, 3)

你可以用子查詢(xún)代替數(shù)組。

$builder->orHavingIn('id', function(BaseBuilder $builder) {
    return $builder->select('user_id')->from('users_jobs')->where('group_id', 3);
});


// 生成: OR "id" IN (SELECT "user_id" FROM "users_jobs" WHERE "group_id" = 3)

$builder->havingNotIn()

生成一個(gè) HAVING 字段的 NOT IN (‘item’, ‘item’) SQL 查詢(xún)子句, 多個(gè)條件之間使用 AND 連接

$groups = [1, 2, 3];
$builder->havingNotIn('group_id', $groups);
// 生成: HAVING group_id NOT IN (1, 2, 3)

你可以用子查詢(xún)代替數(shù)組。

$builder->havingNotIn('id', function(BaseBuilder $builder) {
    return $builder->select('user_id')->from('users_jobs')->where('group_id', 3);
});


// 生成: HAVING "id" NOT IN (SELECT "user_id" FROM "users_jobs" WHERE "group_id" = 3)

$builder->orHavingNotIn()

生成一個(gè) HAVING 字段的 NOT IN (‘item’, ‘item’) SQL 查詢(xún)子句, 多個(gè)條件之間使用 OR 連接

$groups = [1, 2, 3];
$builder->havingNotIn('group_id', $groups);
// 生成: OR group_id NOT IN (1, 2, 3)

你可以用子查詢(xún)代替數(shù)組。

$builder->orHavingNotIn('id', function(BaseBuilder $builder) {
    return $builder->select('user_id')->from('users_jobs')->where('group_id', 3);
});


// 生成: OR "id" NOT IN (SELECT "user_id" FROM "users_jobs" WHERE "group_id" = 3)

$builder->havingLike()

該方法讓你能夠在 HAVING 查詢(xún)部分生成 LIKE 子句,常用于搜索。

注解

該方法所有傳入?yún)?shù)會(huì)被自動(dòng)轉(zhuǎn)義。

havingLike* 通過(guò)傳第五個(gè)參數(shù)傳遞值 true 可以強(qiáng)制在 執(zhí)行查詢(xún)時(shí)不區(qū)分大小寫(xiě)。這項(xiàng)特性可用性跟平臺(tái)相關(guān),否則將強(qiáng)制值轉(zhuǎn)為小寫(xiě), 例如 HAVING LOWER(column) LIKE '%search%',讓其生效可能需要 在制作索引時(shí)用 LOWER(column) 而不是 column

  1. 簡(jiǎn)單 key/value 方式:

   $builder->havingLike('title', 'match');
   // 生成: HAVING `title` LIKE '%match%' ESCAPE '!'

如果你多次調(diào)用該方法,那么多個(gè) WHERE 條件將會(huì)使用 AND 連接起來(lái):

   $builder->havingLike('title', 'match');
   $builder->havingLike('body', 'match');
   // HAVING `title` LIKE '%match%' ESCAPE '!' AND  `body` LIKE '%match% ESCAPE '!'

如果你想控制通配符通配符(%)的位置,可以指定第三個(gè)參數(shù), 可用選項(xiàng):’before’,’after’ 和 ‘both’ (默認(rèn)) 。

   $builder->havingLike('title', 'match', 'before');       // 生成: HAVING `title` LIKE '%match' ESCAPE '!'
   $builder->havingLike('title', 'match', 'after');        // 生成: HAVING `title` LIKE 'match%' ESCAPE '!'
   $builder->havingLike('title', 'match', 'both'); // 生成: HAVING `title` LIKE '%match%' ESCAPE '!'

  1. 關(guān)聯(lián)數(shù)組方式:

   $array = ['title' => $match, 'page1' => $match, 'page2' => $match];
   $builder->havingLike($array);
   // HAVING `title` LIKE '%match%' ESCAPE '!' AND  `page1` LIKE '%match%' ESCAPE '!' AND  `page2` LIKE '%match%' ESCAPE '!'

$builder->orHavingLike()

這個(gè)方法和上面的方法一樣,只是多個(gè)條件之間使用 OR 進(jìn)行連接:

$builder->havingLike('title', 'match'); $builder->orHavingLike('body', $match);
// HAVING `title` LIKE '%match%' ESCAPE '!' OR  `body` LIKE '%match%' ESCAPE '!'

$builder->notHavingLike()

這個(gè)方法和 havingLike() 一樣,只是它生成的是 NOT LIKE 子句:

$builder->notHavingLike('title', 'match');      // HAVING `title` NOT LIKE '%match% ESCAPE '!'

$builder->orNotHavingLike()

這個(gè)方法和 notHavingLike() 一樣,只是多個(gè)條件之間使用 OR 進(jìn)行連接:

$builder->havingLike('title', 'match');
$builder->orNotHavingLike('body', 'match');
// HAVING `title` LIKE '%match% OR  `body` NOT LIKE '%match%' ESCAPE '!'

結(jié)果排序

$builder->orderBy()

該方法用于生成 ORDER BY 子句。

第一個(gè)參數(shù)包含你要排序的列名。

第二個(gè)參數(shù)用于設(shè)置排序的方向, 可選項(xiàng)有: ASCDESCRANDOM 。

$builder->orderBy('title', 'DESC');
// 生成: ORDER BY `title` DESC

第一個(gè)參數(shù)也可以是你自己的排序字符串:

$builder->orderBy('title DESC, name ASC');
// 生成: ORDER BY `title` DESC, `name` ASC

如果需要根據(jù)多個(gè)字段進(jìn)行排序,可以多次調(diào)用該方法。

$builder->orderBy('title', 'DESC');
$builder->orderBy('name', 'ASC');
// 生成: ORDER BY `title` DESC, `name` ASC

如果你選擇了 RANDOM 選項(xiàng),第一個(gè)參數(shù)會(huì)被忽略, 除非你指定第一個(gè)參數(shù)作為隨機(jī)數(shù)的種子。

$builder->orderBy('title', 'RANDOM');
// 生成: ORDER BY RAND()


$builder->orderBy(42, 'RANDOM');
// 生成: ORDER BY RAND(42)

注解

Oracle 目前還不支持隨機(jī)排序,會(huì)默認(rèn)使用 ASC 替代。

結(jié)果分頁(yè)與計(jì)數(shù)

$builder->limit()

該方法可以讓你限制查詢(xún)結(jié)果的返回行數(shù):

$builder->limit(10);  // 生成: LIMIT 10

第二個(gè)參數(shù)可以用來(lái)設(shè)置偏移。

$builder->limit(10, 20);  // 生成: LIMIT 20, 10 (在 MySQL 里的情況,其他數(shù)據(jù)庫(kù)的語(yǔ)法略有不同)

$builder->countAllResults()

該方法用于獲取指定構(gòu)造器查詢(xún)返回的結(jié)果數(shù)量,接受的構(gòu)造器方法有

where() , orWhere() , like() , orLike() 等,例如:

echo $builder->countAllResults('my_table');  // 生成一個(gè)整數(shù),比如 25
$builder->like('title', 'match');
$builder->from('my_table');
echo $builder->countAllResults(); // 生成一個(gè)整數(shù),比如 17

然而,這個(gè)方法會(huì)重置你在 select() 里設(shè)置的所有值, 如果你要保留它們,可以將第一個(gè)參數(shù)設(shè)置為 FALSE:

echo $builder->countAllResults(false); // 生成一個(gè)整數(shù),比如 17

$builder->countAll()

該方法用于獲取指定表的總行數(shù),例如:

echo $builder->countAll();  // 生成一個(gè)整數(shù),比如 25

與 countAllResult 方法一樣,該方法也會(huì)重置你在 select() 里設(shè)置的所有值, 如果你要保留它們,可以將第一個(gè)參數(shù)設(shè)置為 FALSE。

查詢(xún)分組

查詢(xún)分組可以讓你生成用括號(hào)括起來(lái)的一組 WHERE 條件, 這能創(chuàng)造出非常復(fù)雜的 WHERE 子句,支持嵌套的條件組。 例如:

$builder->select('*')->from('my_table')
        ->groupStart()
                ->where('a', 'a')
                ->orGroupStart()
                        ->where('b', 'b')
                        ->where('c', 'c')
                ->groupEnd()
        ->groupEnd()
        ->where('d', 'd')
->get();


// 生成:
// SELECT * FROM (`my_table`) WHERE ( `a` = 'a' OR ( `b` = 'b' AND `c` = 'c' ) ) AND `d` = 'd'

注解

條件組必須要配對(duì),確保每個(gè) groupStart() 方法 都有一個(gè) groupEnd() 方法與之配對(duì)。

$builder->groupStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 WHERE 條件添加一個(gè)左括號(hào)。

$builder->orGroupStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 WHERE 條件添加一個(gè)左括號(hào),并在前面加上 “OR” 。

$builder->notGroupStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 WHERE 條件添加一個(gè)左括號(hào),并在前面加上 “NOT” 。

$builder->orNotGroupStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 WHERE 條件添加一個(gè)左括號(hào),并在前面加上 “OR NOT” 。

$builder->groupEnd()

結(jié)束當(dāng)前的條件組,為查詢(xún)中的 WHERE 條件添加一個(gè)右括號(hào)。

$builder->groupHavingStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 HAVING 條件添加一個(gè)左括號(hào)。

$builder->orGroupHavingStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 HAVING 條件添加一個(gè)左括號(hào),并在前面加上 “OR” 。

$builder->notGroupHavingStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 HAVING 條件添加一個(gè)左括號(hào),并在前面加上 “NOT” 。

$builder->orNotGroupHavingStart()

開(kāi)始一個(gè)新的條件組,為查詢(xún)中的 HAVING 條件添加一個(gè)左括號(hào),并在前面加上 “OR NOT” 。

$builder->groupHavingEnd()

結(jié)束當(dāng)前的條件組,為查詢(xún)中的 HAVING 條件添加一個(gè)右括號(hào)。

插入數(shù)據(jù)

$builder->insert()

該方法根據(jù)你提供的數(shù)據(jù)生成一條 INSERT 語(yǔ)句并執(zhí)行, 它的參數(shù)是一個(gè) 數(shù)組 或一個(gè) 對(duì)象 , 下面是使用數(shù)組的例子:

$data = array(
        'title' => 'My title',
        'name'  => 'My Name',
        'date'  => 'My date'
);


$builder->insert($data);
// 生成: INSERT INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date')

第一個(gè)參數(shù)為要插入的數(shù)據(jù),是個(gè)關(guān)聯(lián)數(shù)組。

下面是使用對(duì)象的例子:

/*
class Myclass {
        public $title   = 'My Title';
        public $content = 'My Content';
        public $date    = 'My Date';
}
*/


$object = new Myclass;
$builder->insert($object);
// 生成: INSERT INTO mytable (title, content, date) VALUES ('My Title', 'My Content', 'My Date')

第一個(gè)參數(shù)為要插入的數(shù)據(jù),是個(gè)對(duì)象。

注解

所有數(shù)據(jù)會(huì)被自動(dòng)轉(zhuǎn)義,生成安全的查詢(xún)語(yǔ)句。

$builder->ignore()

該方法根據(jù)你提供的數(shù)據(jù)生成一條 INSERT IGNORE 語(yǔ)句并執(zhí)行, 如果已經(jīng)存在相同主鍵,該數(shù)據(jù)不會(huì)被插入。 你可以給該方法傳入一個(gè)可選參數(shù),類(lèi)型是 boolean 。 下面是使用數(shù)組的例子:

$data = [
        'title' => 'My title',
        'name'  => 'My Name',
        'date'  => 'My date'
];


$builder->ignore(true)->insert($data);
// 生成: INSERT OR IGNORE INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date')

$builder->getCompiledInsert()

該方法和 $builder->insert() 方法一樣編譯插入查詢(xún),但是 并不執(zhí)行 。 此方法只是將 SQL 查詢(xún)作為字符串返回。

例如:

$data = array(
        'title' => 'My title',
        'name'  => 'My Name',
        'date'  => 'My date'
);


$sql = $builder->set($data)->getCompiledInsert('mytable');
echo $sql;


// 生成字符串: INSERT INTO mytable (`title`, `name`, `date`) VALUES ('My title', 'My name', 'My date')

第二個(gè)參數(shù)用于設(shè)置是否重置查詢(xún)(默認(rèn)會(huì)重置,如 $builder->insert() 方法一樣):

echo $builder->set('title', 'My Title')->getCompiledInsert('mytable', FALSE);


// 生成字符串: INSERT INTO mytable (`title`) VALUES ('My Title')


echo $builder->set('content', 'My Content')->getCompiledInsert();


// 生成字符串: INSERT INTO mytable (`title`, `content`) VALUES ('My Title', 'My Content')

最值得注意的是,上例第二個(gè)查詢(xún)并沒(méi)有用到 $builder->from() 方法, 也沒(méi)有為查詢(xún)指定表名參數(shù)。因?yàn)檫@個(gè)查詢(xún)沒(méi)有被可重置值的 $builder->insert() 方法執(zhí)行,或是使用 $builder->resetQuery() 方法直接重置。

注解

這個(gè)方法不支持批量插入。

$builder->insertBatch()

該方法根據(jù)你提供的數(shù)據(jù)生成一條 INSERT 語(yǔ)句并執(zhí)行, 它的參數(shù)可以是一個(gè) 數(shù)組 或一個(gè) 對(duì)象 , 下面是使用數(shù)組的例子:

$data = array(
        array(
                'title' => 'My title',
                'name'  => 'My Name',
                'date'  => 'My date'
        ),
        array(
                'title' => 'Another title',
                'name'  => 'Another Name',
                'date'  => 'Another date'
        )
);


$builder->insertBatch($data);
// 生成: INSERT INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date'),  ('Another title', 'Another name', 'Another date')

第一個(gè)參數(shù)為要插入的數(shù)據(jù),是個(gè)二維數(shù)組。

注解

所有數(shù)據(jù)會(huì)被自動(dòng)轉(zhuǎn)義,生成安全的查詢(xún)語(yǔ)句。

更新數(shù)據(jù)

$builder->replace()

該方法用于執(zhí)行一條 REPLACE 語(yǔ)句,基本上是(可選)DELETE + INSERT 的 SQL 標(biāo)準(zhǔn), 使用 PRIMARYUNIQUE 鍵作為決定因素。 在我們的例子中,它可以使你免于實(shí)現(xiàn)各種不同邏輯的組合: select() , update() , delete()insert()

例如:

$data = array(
        'title' => 'My title',
        'name'  => 'My Name',
        'date'  => 'My date'
);


$builder->replace($data);


// Executes: REPLACE INTO mytable (title, name, date) VALUES ('My title', 'My name', 'My date')

上面的例子中,我們假設(shè) title 字段是主鍵,那么如果我們數(shù)據(jù)庫(kù)里有一行 包含 ‘My title’ 為標(biāo)題的數(shù)據(jù),那行將被刪除并被我們的新數(shù)據(jù)取代。

也可以使用 set() 方法,而且所有字段都被自動(dòng)轉(zhuǎn)義,正如 insert() 方法一樣。

$builder->set()

該方法可以設(shè)置 insert 或 update 用到的數(shù)據(jù)。

它可以用來(lái)代替直接將數(shù)據(jù)數(shù)組傳遞給 insert 或 update 方法:

$builder->set('name', $name);
$builder->insert();  // 生成: INSERT INTO mytable (`name`) VALUES ('{$name}')

如果你多次調(diào)用該方法,它會(huì)正確組裝出 insert 或 update 語(yǔ)句來(lái):

$builder->set('name', $name);
$builder->set('title', $title);
$builder->set('status', $status);
$builder->insert();

set() 將方法也接受可選的第三個(gè)參數(shù)($escape), 如果設(shè)置為 FALSE ,數(shù)據(jù)將不會(huì)自動(dòng)轉(zhuǎn)義。 為了說(shuō)明區(qū)別,這里有一個(gè)帶轉(zhuǎn)義的 set() 方法和不帶轉(zhuǎn)義的例子。

$builder->set('field', 'field+1', FALSE);
$builder->where('id', 2);
$builder->update(); // 生成 UPDATE mytable SET field = field+1 WHERE `id` = 2


$builder->set('field', 'field+1');
$builder->where('id', 2);
$builder->update(); // 生成 UPDATE `mytable` SET `field` = 'field+1' WHERE `id` = 2

你也可以傳一個(gè)關(guān)聯(lián)數(shù)組作為參數(shù):

$array = array(
        'name'   => $name,
        'title'  => $title,
        'status' => $status
);


$builder->set($array);
$builder->insert();

或者一個(gè)對(duì)象:

/*
class Myclass {
        public $title   = 'My Title';
        public $content = 'My Content';
        public $date    = 'My Date';
}
*/


$object = new Myclass;
$builder->set($object);
$builder->insert();

$builder->update()

該方法根據(jù)你提供的數(shù)據(jù)生成更新字符串并執(zhí)行,它的參數(shù)是一個(gè) 數(shù)組 或一個(gè) 對(duì)象 ,下面是使用數(shù)組的例子:

$data = array(
        'title' => $title,
        'name'  => $name,
        'date'  => $date
);


$builder->where('id', $id);
$builder->update($data);
// 生成:
//
//      UPDATE mytable
//      SET title = '{$title}', name = '{$name}', date = '{$date}'
//      WHERE id = $id

或者你可以使用一個(gè)對(duì)象:

/*
class Myclass {
        public $title   = 'My Title';
        public $content = 'My Content';
        public $date    = 'My Date';
}
*/


$object = new Myclass;
$builder->where('id', $id);
$builder->update($object);
// 生成:
//
// UPDATE `mytable`
// SET `title` = '{$title}', `name` = '{$name}', `date` = '{$date}'
// WHERE id = `$id`

注解

所有數(shù)據(jù)會(huì)被自動(dòng)轉(zhuǎn)義,生成安全的查詢(xún)語(yǔ)句。

你應(yīng)該注意到用 $builder->where() 方法可以為你設(shè)置 WHERE 子句。 你可以選擇性的將這些(條件)信息直接以字符串傳入 update 方法:

$builder->update($data, "id = 4");

或者使用一個(gè)數(shù)組:

$builder->update($data, array('id' => $id));

當(dāng)執(zhí)行更新操作時(shí),你還可以使用上面介紹的 $builder->set() 方法。

$builder->updateBatch()

該方法根據(jù)你提供的數(shù)據(jù)生成一條 UPDATE 語(yǔ)句并執(zhí)行,它的參數(shù)是一個(gè) 數(shù)組 或一個(gè) 對(duì)象 ,下面是使用數(shù)組的例子:

$data = array(
   array(
      'title' => 'My title' ,
      'name'  => 'My Name 2' ,
      'date'  => 'My date 2'
   ),
   array(
      'title' => 'Another title' ,
      'name'  => 'Another Name 2' ,
      'date'  => 'Another date 2'
   )
);


$builder->updateBatch($data, 'title');


// 生成:
// UPDATE `mytable` SET `name` = CASE
// WHEN `title` = 'My title' THEN 'My Name 2'
// WHEN `title` = 'Another title' THEN 'Another Name 2'
// ELSE `name` END,
// `date` = CASE
// WHEN `title` = 'My title' THEN 'My date 2'
// WHEN `title` = 'Another title' THEN 'Another date 2'
// ELSE `date` END
// WHERE `title` IN ('My title','Another title')

第一個(gè)參數(shù)為要更新的數(shù)據(jù),是個(gè)二維數(shù)組,第二個(gè)參數(shù)是 where 語(yǔ)句的鍵。

注解

所有數(shù)據(jù)會(huì)被自動(dòng)轉(zhuǎn)義,生成安全的查詢(xún)語(yǔ)句。

由于該方法的內(nèi)部實(shí)現(xiàn),在這之后調(diào)用 affectedRows() 方法的返回值可能不正確,替代辦法是用 updateBatch() 的返回值,表示受影響的行數(shù)。

$builder->getCompiledUpdate()

該方法和 $builder->getCompiledInsert() 方法完全一樣, 除了生成的 SQL 語(yǔ)句是 UPDATE 而不是 INSERT。

查看 $builder->getCompiledInsert() 方法的文檔獲取更多信息。

注解

該方法不支持批量更新。

刪除數(shù)據(jù)

$builder->delete()

該方法生成刪除SQL語(yǔ)句并執(zhí)行。

$builder->delete(array('id' => $id));  // 生成: // DELETE FROM mytable  // WHERE id = $id

第一個(gè)參數(shù)為 where 子句。你也可以使用 where() 或 or_where() 方法替代第一個(gè)參數(shù):

$builder->where('id', $id);
$builder->delete();


// 生成:
// DELETE FROM mytable
// WHERE id = $id

如果你想刪除一個(gè)表中的全部數(shù)據(jù),可以使用 truncate() 或 emptyTable() 方法。

$builder->emptyTable()

該方法生成刪除 SQl 語(yǔ)句并執(zhí)行:

$builder->emptyTable('mytable'); // 生成: DELETE FROM mytable

$builder->truncate()

該方法生截?cái)?SQL 語(yǔ)句并執(zhí)行。

$builder->truncate();


// 生成:
// TRUNCATE mytable

注解

如果 TRUNCATE 命令不可用,truncate() 方法將執(zhí)行 “DELETE FROM table”。

$builder->getCompiledDelete()

該方法和 $builder->getCompiledInsert() 方法完全一樣, 除了生成的 SQL 語(yǔ)句是 DELETE 而不是 INSERT。

查看 $builder->getCompiledInsert() 方法的文檔獲取更多信息。

鏈?zhǔn)椒椒?/h2>

通過(guò)將多個(gè)方法連接在一起,鏈?zhǔn)椒椒梢源蟠蠛?jiǎn)化你的語(yǔ)法。感受一下這個(gè)例子:

$query = $builder->select('title')
                 ->where('id', $id)
                 ->limit(10, 20)
                 ->get();

重置查詢(xún)構(gòu)造器

$builder->resetQuery()

該方法使你可以重置查詢(xún)構(gòu)造器,而無(wú)需先執(zhí)行例如 $builder->get() 或 $builder->insert() 這類(lèi)方法。

當(dāng)你要用查詢(xún)構(gòu)造器生成 SQL 語(yǔ)句(如: $builder->getCompiledSelect() ), 之后再執(zhí)行它,這種情況下,不重置查詢(xún)構(gòu)造器很有用:

    // 注意 get_compiled_select 方法的第二個(gè)參數(shù)為 FALSE
$sql = $builder->select(['field1','field2'])
               ->where('field3',5)
               ->getCompiledSelect(false);


// ...
// 用 SQL 代碼做一些瘋狂的事情... 比如將它添加到 cron 腳本中
// 以后執(zhí)行還是什么...
// ...


$data = $builder->get()->getResultArray();


// 會(huì)執(zhí)行并返回以下查詢(xún)的結(jié)果數(shù)組嗎:
// SELECT field1, field1 from mytable where field3 = 5;

類(lèi)庫(kù)參考

*class*`CodeIgniterDatabaseBaseBuilder`

resetQuery()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

重置當(dāng)前查詢(xún)構(gòu)造器狀態(tài)。當(dāng)你需要構(gòu)建一個(gè)可在某些情況下取消的查詢(xún)時(shí)有用。

countAllResults([$reset = TRUE])

參數(shù): $reset (bool) – 是否重置 SELECT 的值
返回: 查詢(xún)結(jié)果中的行數(shù)
返回類(lèi)型: int

生成特定于平臺(tái)的查詢(xún)語(yǔ)句,用于計(jì)數(shù)查詢(xún)構(gòu)造器返回的行數(shù)。

countAll([$reset = TRUE])

參數(shù): $reset (bool) – 是否重置 SELECT 的值
返回: 查詢(xún)結(jié)果中的行數(shù)
返回類(lèi)型: int

生成特定于平臺(tái)的查詢(xún)語(yǔ)句,用于計(jì)數(shù)查詢(xún)構(gòu)造器返回的行數(shù)。

get([$limit = NULL[, $offset = NULL]])

參數(shù): $limit (int) – LIMIT 子句
$offset (int) – OFFSET 子句
返回: CodeIgniterDatabaseResultInterface instance (方法鏈)
返回類(lèi)型: CodeIgniterDatabaseResultInterface

基于已經(jīng)調(diào)用過(guò)的查詢(xún)構(gòu)造器方法,編譯執(zhí)行 SELECT 查詢(xún)。

getWhere([$where = NULL[, $limit = NULL[, $offset = NULL]]])

參數(shù): $where (string) – WHERE 子句
$limit (int) – LIMIT 子句
$offset (int) – OFFSET 子句
返回: CodeIgniterDatabaseResultInterface instance (方法鏈)
返回類(lèi)型: CodeIgniterDatabaseResultInterface

get() 相同,但也允許直接添加 WHERE 。

select([$select = '*'[, $escape = NULL]])

參數(shù): $select (string) – 查詢(xún)的 SELECT 部分
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 SELECT 子句。

selectAvg([$select = ''[, $alias = '']])

參數(shù): $select (string) – 用于計(jì)算平均值的字段
$alias (string) – 結(jié)果值名稱(chēng)的別名
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 SELECT AVG(field) 子句。

selectMax([$select = ''[, $alias = '']])

參數(shù): $select (string) – 用于計(jì)算最大值的字段
$alias (string) – 結(jié)果值名稱(chēng)的別名
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 SELECT MAX(field) 子句。

selectMin([$select = ''[, $alias = '']])

參數(shù): $select (string) – 用于計(jì)算最小值的字段
$alias (string) – 結(jié)果值名稱(chēng)的別名
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 SELECT MIN(field) 子句。

selectSum([$select = ''[, $alias = '']])

參數(shù): $select (string) – 字段來(lái)計(jì)算總和
$alias (string) – 結(jié)果值名稱(chēng)的別名
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 SELECT SUM(field) 子句。

selectCount([$select = ''[, $alias = '']])

參數(shù): $select (string) – 用于計(jì)算記錄總和的字段
$alias (string) – 結(jié)果值名稱(chēng)的別名
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 SELECT COUNT(field) 子句。

distinct([$val = TRUE])

參數(shù): $val (bool) – 預(yù)期的 “distinct” 標(biāo)志值
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

設(shè)置一個(gè)標(biāo)志, 告訴查詢(xún)構(gòu)建器給 SELECT 部分添加 DISTINCT 子句。

from($from[, $overwrite = FALSE])

參數(shù): $from (mixed) – Table name(s); 字符串或數(shù)組
$overwrite (bool) – 是否移除第一個(gè)設(shè)置的表?
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

指定查詢(xún)的 FROM 子句。

join($table, $cond[, $type = ''[, $escape = NULL]])

參數(shù): $table (string) – 要 join 的表名
$cond (string) – JOIN ON 條件
$type (string) – JOIN 類(lèi)型
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加JOIN子句。

where($key[, $value = NULL[, $escape = NULL]])

參數(shù): $key (mixed) – 要比較的字段名稱(chēng)或關(guān)聯(lián)數(shù)組
$value (mixed) – 如果是單個(gè)鍵,則與此值相比
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

生成查詢(xún)的 WHERE 部分,用 ‘AND’ 分隔多個(gè)調(diào)用。

orWhere($key[, $value = NULL[, $escape = NULL]])

參數(shù): $key (mixed) – 要比較的字段名稱(chēng)或關(guān)聯(lián)數(shù)組
$value (mixed) – 如果是單個(gè)鍵,則與此值相比
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

生成查詢(xún)的 WHERE 部分,用 ‘OR’ 分隔多個(gè)調(diào)用。

orWhereIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要搜索的字段
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

生成一個(gè) WHERE 字段 IN(‘item’, ‘item’) SQL 查詢(xún),多個(gè)用 ‘OR’ 連接。

orWhereNotIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要搜索的字段
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

生成一個(gè) WHERE 字段 NOT IN(‘item’, ‘item’) SQL 查詢(xún),多個(gè)用 ‘OR’ 連接。

whereIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要檢查的字段的名稱(chēng)
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

生成一個(gè) WHERE 字段 IN(‘item’, ‘item’) SQL 查詢(xún),多個(gè)用 ‘AND’ 連接。

whereNotIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要檢查的字段的名稱(chēng)
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

生成一個(gè) WHERE 字段 NOT IN(‘item’, ‘item’) SQL 查詢(xún),多個(gè)用 ‘AND’ 連接。

groupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng)組表達(dá)式,使用 AND 連接其中的條件。

orGroupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng)組表達(dá)式,使用 OR 連接其中的條件。

notGroupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng)組表達(dá)式,使用 AND NOT 連接其中的條件。

orNotGroupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng)組表達(dá)式,使用 OR NOT 連接其中的條件。

groupEnd()

返回: BaseBuilder instance
返回類(lèi)型: object

完成一個(gè)組表達(dá)式。

like($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 LIKE 子句,用 AND 分隔多個(gè)調(diào)用。

orLike($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 LIKE 子句,用 OR 分隔多個(gè)調(diào)用。

notLike($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 NOT LIKE 子句,用 AND 分隔多個(gè)調(diào)用。

orNotLike($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 NOT LIKE 子句,用 OR 分隔多個(gè)調(diào)用。

having($key[, $value = NULL[, $escape = NULL]])

參數(shù): $key (mixed) – 標(biāo)識(shí)符(字符串)或 field/value 對(duì)的關(guān)聯(lián)數(shù)組
$value (string) – 如果 $key 是標(biāo)識(shí)符,則尋求此值
$escape (string) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 HAVING 子句,用 AND 分隔多個(gè)調(diào)用。

orHaving($key[, $value = NULL[, $escape = NULL]])

參數(shù): $key (mixed) – 標(biāo)識(shí)符(字符串)或 field/value 對(duì)的關(guān)聯(lián)數(shù)組
$value (string) – 如果 $key 是標(biāo)識(shí)符,則尋求此值
$escape (string) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 HAVING 子句,用 OR 分隔多個(gè)調(diào)用。

orHavingIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要檢索的字段名
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

向查詢(xún)添加 HAVING 字段 IN(‘item’, ‘item’) 子句,多個(gè)用 OR 連接。

orHavingNotIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要檢索的字段名
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

向查詢(xún)添加 HAVING 字段 NOT IN(‘item’, ‘item’) 子句,多個(gè)用 OR 連接。

havingIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要檢索的字段名
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

向查詢(xún)添加 HAVING 字段 IN(‘item’, ‘item’) 子句,多個(gè)用 AND 連接。

havingNotIn([$key = NULL[, $values = NULL[, $escape = NULL]]])

參數(shù): $key (string) – 要檢索的字段名
$values (array/Closure) – 目標(biāo)值的數(shù)組,或子查詢(xún)的匿名函數(shù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance
返回類(lèi)型: object

向查詢(xún)添加 HAVING 字段 NOT IN(‘item’, ‘item’) 子句,多個(gè)用 AND 連接。

havingLike($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)的 HAVING 部分添加 LIKE 子句,用 AND 分隔多個(gè)調(diào)用。

orHavingLike($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)的 HAVING 部分添加 LIKE 子句,用 OR 分隔多個(gè)調(diào)用。

notHavingLike($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)的 HAVING 部分添加 NOT LIKE 子句,用 AND 分隔多個(gè)調(diào)用。

orNotHavingLike($field[, $match = ''[, $side = 'both'[, $escape = NULL[, $insensitiveSearch = FALSE]]]])

參數(shù): $field (string) – 字段名
$match (string) – 匹配的文本部分
$side (string) – 將 ‘%’ 通配符放在表達(dá)式的哪一側(cè)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$insensitiveSearch (bool) – 是否強(qiáng)制大小寫(xiě)不敏感檢索
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)的 HAVING 部分添加 NOT LIKE 子句,用 OR 分隔多個(gè)調(diào)用。

havingGroupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng) HAVING 子句的組表達(dá)式,使用 AND 連接其中的條件。

orHavingGroupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng) HAVING 子句的組表達(dá)式,使用 OR 連接其中的條件。

notHavingGroupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng) HAVING 子句的組表達(dá)式,使用 AND NOT 連接其中的條件。

orNotHavingGroupStart()

返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

啟動(dòng) HAVING 子句的組表達(dá)式,使用 OR NOT 連接其中的條件。

havingGroupEnd()

返回: BaseBuilder instance
返回類(lèi)型: object

完成一個(gè) HAVING 子句的組表達(dá)式。

groupBy($by[, $escape = NULL])

參數(shù): $by (mixed) – 根據(jù)字段分組; 字符串或數(shù)組
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 GROUP BY 子句。

orderBy($orderby[, $direction = ''[, $escape = NULL]])

參數(shù): $orderby (string) – 根據(jù)字段排序
$direction (string) – 要求的排序 - ASC , DESC 或 RANDOM
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 ORDER BY 子句。

limit($value[, $offset = 0])

參數(shù): $value (int) – 限制返回行數(shù)
$offset (int) – 偏移行數(shù)
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 LIMIT 和 OFFSET 子句。

offset($offset)

參數(shù): $offset (int) – 偏移行數(shù)
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

向查詢(xún)添加 OFFSET 子句。

set($key[, $value = ''[, $escape = NULL]])

參數(shù): $key (mixed) – 字段名或 field/value 對(duì)的關(guān)聯(lián)數(shù)組
$value (string) – 字段值,如果 $key 是單個(gè)字段
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

添加 field/value 鍵值對(duì),稍后用于傳遞給 insert() , update()replace() 。

insert([$set = NULL[, $escape = NULL]])

參數(shù): $set (array) – field/value 對(duì)的關(guān)聯(lián)數(shù)組
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: 成功時(shí)為 TRUE,失敗時(shí)為 FALSE
返回類(lèi)型: bool

編譯并執(zhí)行 INSERT 語(yǔ)句。

insertBatch([$set = NULL[, $escape = NULL[, $batch_size = 100]]])

參數(shù): $set (array) – 要插入的數(shù)據(jù)
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
$batch_size (int) – 要一次插入的行數(shù)
返回: 插入的行數(shù)或失敗時(shí)的 FALSE
返回類(lèi)型: mixed

編譯并執(zhí)行批量的 INSERT 語(yǔ)句。

注解

當(dāng)數(shù)據(jù)超過(guò) $batch_size 行時(shí),將執(zhí)行多個(gè) INSERT 查詢(xún), 每次嘗試插入最多為 $batch_size 行。

setInsertBatch($key[, $value = ''[, $escape = NULL]])

參數(shù): $key (mixed) – 字段名或 field/value 對(duì)應(yīng)的關(guān)聯(lián)數(shù)組
$value (string) – 字段值,如果 $key 是單個(gè)字段
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

添加 field/value 鍵值對(duì),稍后通過(guò) insertBatch() 向一個(gè)表插入。

update([$set = NULL[, $where = NULL[, $limit = NULL]]])

參數(shù): $set (array) – field/value 對(duì)應(yīng)的關(guān)聯(lián)數(shù)組
$where (string) – WHERE 子句
$limit (int) – LIMIT 子句
返回: TRUE 為成功, FALSE 為失敗
返回類(lèi)型: bool

編譯并執(zhí)行 UPDATE 語(yǔ)句。

updateBatch([$set = NULL[, $value = NULL[, $batch_size = 100]]])

參數(shù): $set (array) – 字段名,或 field/value 對(duì)的關(guān)聯(lián)數(shù)組
$value (string) – 字段值,如果 $set 是單個(gè)字段
$batch_size (int) – 在單個(gè)查詢(xún)中分組的條件計(jì)數(shù)
返回: 更新的行數(shù)或失敗時(shí)的 FALSE
返回類(lèi)型: mixed

編譯并執(zhí)行批量的 UPDATE 語(yǔ)句。

注解

當(dāng)數(shù)據(jù)超過(guò) $batch_size 行時(shí),將執(zhí)行多個(gè) INSERT 查詢(xún), 每次最多處理 $batch_size 行。

setUpdateBatch($key[, $value = ''[, $escape = NULL]])

參數(shù): $key (mixed) – 字段名,或 field/value 對(duì)的關(guān)聯(lián)數(shù)組
$value (string) – 字段值,如果 $key 是單個(gè)字段
$escape (bool) – 是否轉(zhuǎn)義值和標(biāo)識(shí)符
返回: BaseBuilder instance (方法鏈)
返回類(lèi)型: BaseBuilder

添加 field/value 鍵值對(duì),稍后通過(guò) updateBatch() 更新一個(gè)表。

replace([$set = NULL])

參數(shù): $set (array) – field/value 對(duì)應(yīng)的關(guān)聯(lián)數(shù)組
返回: TRUE 為成功, FALSE 為失敗
返回類(lèi)型: bool

編譯并執(zhí)行 REPLACE 語(yǔ)句。

delete([$where = ''[, $limit = NULL[, $reset_data = TRUE]]])

參數(shù): $where (string) – WHERE 子句
$limit (int) – LIMIT 子句
$reset_data (bool) – TRUE 會(huì)重置查詢(xún) “write” 子句
返回: BaseBuilder instance (方法鏈) 或者失敗時(shí)為 FALSE
返回類(lèi)型: mixed

編譯并執(zhí)行 DELETE 查詢(xún)。

increment($column[, $value = 1])

參數(shù): $column (string) – 要遞增的列的名稱(chēng)
$value (int) –要給列增加的數(shù)值給一個(gè)字段增加指定量的數(shù)值,如果該字段不是數(shù)字型字段,比如如 VARCHAR , 它可能會(huì)被新的 $value 值替換。

decrement($column[, $value = 1])

參數(shù): $column (string) – 要減少的列的名稱(chēng)
$value (int) –要給列減少的數(shù)值給一個(gè)字段減去指定量的數(shù)值,如果該字段不是數(shù)字型字段,比如如 VARCHAR , 它可能會(huì)被新的 $value 值替換。

truncate()

返回: TRUE 為成功, FALSE 為失敗
返回類(lèi)型: bool

在表上執(zhí)行 TRUNCATE 語(yǔ)句。

注解

如果所用的數(shù)據(jù)庫(kù)平臺(tái)不支持 TRUNCATE ,將使用 DELETE 語(yǔ)句替代。

emptyTable()

返回: TRUE 為成功, FALSE 為失敗
返回類(lèi)型: bool

通過(guò) DELETE 語(yǔ)句刪除表中所有記錄。

getCompiledSelect([$reset = TRUE])

參數(shù): $reset (bool) – 是否重置當(dāng)前查詢(xún)構(gòu)造器(QB)的值
返回: 已編譯的 SQL 語(yǔ)句為字符串
返回類(lèi)型: string

編譯 SELECT 語(yǔ)句并將其作為字符串返回。

getCompiledInsert([$reset = TRUE])

參數(shù): $reset (bool) – 是否重置當(dāng)前查詢(xún)構(gòu)造器(QB)的值
返回: 已編譯的 SQL 語(yǔ)句為字符串
返回類(lèi)型: string

編譯 INSERT 語(yǔ)句并將其作為字符串返回。

getCompiledUpdate([$reset = TRUE])

參數(shù): $reset (bool) – 是否重置當(dāng)前查詢(xún)構(gòu)造器(QB)的值
返回: 已編譯的 SQL 語(yǔ)句為字符串
返回類(lèi)型: string

編譯 UPDATE 語(yǔ)句并將其作為字符串返回。

getCompiledDelete([$reset = TRUE])

參數(shù): $reset (bool) – 是否重置當(dāng)前查詢(xún)構(gòu)造器(QB)的值
返回: 已編譯的 SQL 語(yǔ)句為字符串
返回類(lèi)型: string

編譯 DELETE 語(yǔ)句并將其作為字符串返回。

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)