laravel5.1框架model類(lèi)查詢(xún)的實(shí)現(xiàn)方法
laravel框架model類(lèi)查詢(xún)實(shí)現(xiàn):
User::where(['uid'=8])->get();
User類(lèi)繼承自Model類(lèi):Illuminate\Database\Eloquent\Model
當(dāng)User類(lèi)靜態(tài)調(diào)用where方法時(shí),自動(dòng)調(diào)用了Model里的魔術(shù)方法:
public static function __callStatic($method, $parameters)
{
$instance = new static; //這里的$instance就是User類(lèi)的實(shí)例對(duì)象
return call_user_func_array([$instance, $method], $parameters);
}
相當(dāng)于調(diào)用了user對(duì)象的where方法,這時(shí)就又調(diào)用了魔術(shù)方法:
public function __call($method, $parameters)
{
if (in_array($method, ['increment', 'decrement'])) {
return call_user_func_array([$this, $method], $parameters);
}
$query = $this->newQuery(); //返回Illuminate\Database\Eloquent\Builder對(duì)象
return call_user_func_array([$query, $method], $parameters);
}
相當(dāng)于調(diào)用Illuminate\Database\Eloquent\Builder對(duì)象里的where方法和get方法,這兩個(gè)方法里其實(shí)
其實(shí)是封裝調(diào)用了Illuminate\Database\Query\Builder對(duì)象里的where方法和get方法->get方法里調(diào)用了runselect方法
runSelect方法:
/**
* Run the query as a "select" statement against the connection.
*
* @return array
*/
protected function runSelect()
{
return $this->connection->select($this->toSql(), $this->getBindings(), ! $this->useWritePdo); //調(diào)用connection 對(duì)象的select方法
}
再看connection對(duì)象是怎么傳到Illuminate\Database\Eloquent\Builder類(lèi)實(shí)例里的:
Model類(lèi)的newQuery方法:
/**
* Get a new query builder for the model's table.
*
* @return \Illuminate\Database\Eloquent\Builder
*/
public function newQuery()
{
$builder = $this->newQueryWithoutScopes();
return $this->applyGlobalScopes($builder);
}
Model類(lèi)的newQueryWithoutScopes方法:
/**
* Get a new query builder that doesn't have any global scopes.
*
* @return \Illuminate\Database\Eloquent\Builder|static
*/
public function newQueryWithoutScopes()
{
$builder = $this->newEloquentBuilder(
$this->newBaseQueryBuilder() //這個(gè)方法返回
);
// Once we have the query builders, we will set the model instances so the
// builder can easily access any information it may need from the model
// while it is constructing and executing various queries against it.
return $builder->setModel($this)->with($this->with);
}
Model類(lèi)的newBaseQueryBuilder方法實(shí)現(xiàn)
/**
* Get a new query builder instance for the connection.
*
* @return \Illuminate\Database\Query\Builder
*/
protected function newBaseQueryBuilder()
{
$conn = $this->getConnection(); \\連接數(shù)據(jù)庫(kù)并返回connection對(duì)象
$grammar = $conn->getQueryGrammar();
return new QueryBuilder($conn, $grammar, $conn->getPostProcessor()); //Illuminate\Database\Query\Builder
}
Model類(lèi)的$resolver屬性(連接解析器)的設(shè)定是通過(guò)
Illuminate\Database\DatabaseServiceProvider 里的boot方法設(shè)置的
這樣Model類(lèi)的getConnection方法實(shí)際調(diào)用的DatabaseManager類(lèi)的connection方法,返回connection類(lèi)實(shí)例
如何創(chuàng)建的數(shù)據(jù)庫(kù)連接:
Model類(lèi)getConnection方法->DatabaseManager類(lèi)connection方法->
->ConnectionFactory類(lèi)的createSingleConnection()
/**
* Create a single database connection instance.
*
* @param array $config
* @return \Illuminate\Database\Connection
*/
protected function createSingleConnection(array $config)
{
//創(chuàng)建連接器對(duì)象并連接數(shù)據(jù)庫(kù)返回pdo對(duì)象
$pdo = $this->createConnector($config)->connect($config);
//傳入PDO對(duì)象、并返回connection對(duì)象,connection對(duì)象負(fù)責(zé)查詢(xún)數(shù)據(jù)庫(kù)
return $this->createConnection($config['driver'], $pdo, $config['database'], $config['prefix'], $config);
}
以上這篇laravel5.1框架model類(lèi)查詢(xún)的實(shí)現(xiàn)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 在Laravel5中正確設(shè)置文件權(quán)限的方法
- Laravel5權(quán)限管理方法詳解
- Laravel框架實(shí)現(xiàn)的rbac權(quán)限管理操作示例
- laravel實(shí)現(xiàn)簡(jiǎn)單用戶(hù)權(quán)限的示例代碼
- 解決laravel中日志權(quán)限莫名變成了root的問(wèn)題
- laravel利用中間件做防非法登錄和權(quán)限控制示例
- Laravel5.1數(shù)據(jù)庫(kù)連接、創(chuàng)建數(shù)據(jù)庫(kù)、創(chuàng)建model及創(chuàng)建控制器的方法
- laravel5.1框架基礎(chǔ)之Blade模板繼承簡(jiǎn)單使用方法分析
- Laravel5.1框架注冊(cè)中間件的三種場(chǎng)景詳解
- laravel5.1框架基礎(chǔ)之路由詳解
- Laravel5.1框架自帶權(quán)限控制系統(tǒng) ACL用法分析
相關(guān)文章
Django中通過(guò)定時(shí)任務(wù)觸發(fā)頁(yè)面靜態(tài)化的處理方式
Django是一個(gè)開(kāi)放源代碼的Web應(yīng)用框架,由Python寫(xiě)成。這篇文章主要介紹了Django中通過(guò)定時(shí)任務(wù)觸發(fā)頁(yè)面靜態(tài)化的方式,需要的朋友可以參考下2018-08-08
Codeigniter出現(xiàn)錯(cuò)誤提示Error with CACHE directory的解決方案
這篇文章主要介紹了Codeigniter出現(xiàn)錯(cuò)誤提示Error with CACHE directory的解決方案,需要的朋友可以參考下2014-06-06
PHP后臺(tái)備份MySQL數(shù)據(jù)庫(kù)的源碼實(shí)例
今天小編就為大家分享一篇關(guān)于PHP后臺(tái)備份MySQL數(shù)據(jù)庫(kù)的源碼實(shí)例,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03
cakephp2.X多表聯(lián)合查詢(xún)join及使用分頁(yè)查詢(xún)的方法
這篇文章主要介紹了cakephp2.X多表聯(lián)合查詢(xún)join及使用分頁(yè)查詢(xún)的方法,結(jié)合實(shí)例形式簡(jiǎn)單分析了cakephp查詢(xún)及分頁(yè)操作相關(guān)技巧,需要的朋友可以參考下2017-02-02
php使用異或?qū)崿F(xiàn)的加密解密實(shí)例
字符串的加密解密在數(shù)據(jù)的處理中應(yīng)該是經(jīng)常使用的,但MD5加密是不可逆的,所以自能自己動(dòng)手寫(xiě)一個(gè)加密解密函數(shù),思路很。網(wǎng)上看了幾個(gè)用異或?qū)崿F(xiàn)的思路,看懂后就自己寫(xiě)了一下。異或的思路很簡(jiǎn)單,用個(gè)公示簡(jiǎn)單的表示下吧2013-09-09
php設(shè)置頁(yè)面超時(shí)時(shí)間解決方法
大家都遇到過(guò)由于網(wǎng)絡(luò)卡導(dǎo)致的網(wǎng)頁(yè)一直在轉(zhuǎn)吧,看到此現(xiàn)象我想是不是可以給網(wǎng)頁(yè)設(shè)置一個(gè)超時(shí)時(shí)間,設(shè)置一個(gè)時(shí)間多久沒(méi)反應(yīng)就提示超時(shí)信息呢?下面看看小編是怎么實(shí)現(xiàn)php設(shè)置頁(yè)面超時(shí)時(shí)間的吧2015-09-09
PHP 下載文件時(shí)如何自動(dòng)添加bom頭及解釋BOM頭和去掉bom頭的方法
在utf-8編碼文件中BOM在文件頭部,占用三個(gè)字節(jié),用來(lái)標(biāo)示該文件屬于utf-8編碼,現(xiàn)在已經(jīng)有很多軟件識(shí)別bom頭,但是還有些不能識(shí)別bom頭,比如PHP就不能識(shí)別bom頭,這也是用記事本編輯utf-8編碼后執(zhí)行就會(huì)出錯(cuò)的原因了2016-01-01
php對(duì)包含html標(biāo)簽的字符串進(jìn)行截取的函數(shù)分享
這篇文章主要介紹了php對(duì)包含html標(biāo)簽的字符串進(jìn)行截取的函數(shù)分享,相比普通的字符串截取更為強(qiáng)大,用在一些特殊場(chǎng)合,需要的朋友可以參考下2014-06-06

