SELECT和WHERE里面,遇到多表都有的名字,一定要使用表名以區(qū)別,電腦才知道你的命令,才能正確執(zhí)行。
創(chuàng)新互聯(lián)公司專注于寧夏企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),商城網(wǎng)站定制開發(fā)。寧夏網(wǎng)站建設(shè)公司,為寧夏等地區(qū)提供建站服務(wù)。全流程按需求定制制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
當(dāng)SELECT后面的名字不重復(fù)的時(shí)候,多表都有的列但是只選了一份,在GROUP和ORDER里面可以不用加表名,計(jì)算機(jī)能夠推斷是哪個(gè)。
比如你有兩個(gè)表 ?pre_first ?pre_second 并且你數(shù)據(jù)庫配置文件已經(jīng)配置了表前綴那么你可以這么寫
$First=new?\Think\Model("First");
//聯(lián)表查詢條件
$arrJoin=array(
"__SECOND__?as?s?on?f.id=s.id?",?
);
$list=$First-alias('f')-join($arrJoin,'LEFT')-select();
沒有區(qū)別吧,如果表名過長,起別名可以簡化sql語句,如果涉及一個(gè)表,就不用,在性能方面的影響微乎其微啊。
查詢優(yōu)化器首先先執(zhí)行from子句,碰到表名有別名就直接使用了,而后面不是每次都解析的。
但是自身連接時(shí)必須使用兩個(gè)別名。
thinkphp的關(guān)聯(lián)模型,就是簡化你的jion操作。所以,本質(zhì)上,關(guān)聯(lián)模型,就是處理表連接關(guān)系的。歸根結(jié)底的,就是讓你在用模型操作的時(shí)候,簡化SQL查詢的join操作。(是簡化操作,而不是改變SQL語句。)
先舉個(gè)例子。一個(gè)用戶表,一個(gè)文章表。一個(gè)用戶對(duì)應(yīng)多篇文章。然后,你現(xiàn)在會(huì)經(jīng)常出現(xiàn)如下需求:取得某人的文章記錄,但是呢,只要求顯示,用戶名,文章名,文章ID,文章日期(其他的,比如,什么用戶郵箱啊,用戶密碼啊,文章類型啊,文章修改日期啊,文章標(biāo)簽啊,你都不需要)這個(gè)時(shí)候,你就可以定義一個(gè)試圖模型,然后在?$viewFields?里面,就可以把你經(jīng)常使用需要調(diào)用的那個(gè)幾個(gè)字段,按照thinkphp的規(guī)定,定義進(jìn)去。
如下參考
class?ArticleViewModel?extends?ViewModel?{
public?$viewFields?=?array(
'Article'=array('name','title'....其他字段),
'Author'=array('title'='category_name',?'_on'='article.auid=author.id'),
'Article_class'=array(字段定義如上,具體規(guī)則,下面有介紹,?'_on'=上面已經(jīng)給你寫了一個(gè),這里其實(shí)就是寫,article,和article_class?的主外鍵,對(duì)應(yīng)關(guān)系。即JOIN?....ON..語句,ON部分的多內(nèi)容),
'article_type'=array('field_realename'='field_alias'。這里就相當(dāng)于查詢語句SELECT?字段??字段的別名。這樣的對(duì)應(yīng)關(guān)系。)?
);
}