視圖模型
目前成都創(chuàng)新互聯(lián)公司已為近1000家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機、網(wǎng)站托管維護、企業(yè)網(wǎng)站設(shè)計、寶興網(wǎng)站維護等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
視圖定義
視圖通常是指數(shù)據(jù)庫的視圖,視圖是一個虛擬表,其內(nèi)容由查詢定義。同真實的表一樣,視圖包含一系列帶有名稱的列和行數(shù)據(jù)。但是,視圖并不在數(shù)據(jù)庫中以存儲的數(shù)據(jù)值集形式存在。行和列數(shù)據(jù)來自由定義視圖的查詢所引用的表,并且在引用視圖時動態(tài)生成。對其中所引用的基礎(chǔ)表來說,視圖的作用類似于篩選。定義視圖的篩選可以來自當(dāng)前或其它數(shù)據(jù)庫的一個或多個表,或者其它視圖。分布式查詢也可用于定義使用多個異類源數(shù)據(jù)的視圖。如果有幾臺不同的服務(wù)器分別存儲組織中不同地區(qū)的數(shù)據(jù),而您需要將這些服務(wù)器上相似結(jié)構(gòu)的數(shù)據(jù)組合起來,這種方式就很有用。
視圖在有些數(shù)據(jù)庫下面并不被支持,但是ThinkPHP模擬實現(xiàn)了數(shù)據(jù)庫的視圖,該功能可以用于多表聯(lián)合查詢。非常適合解決HAS_ONE 和 BELONGS_TO 類型的關(guān)聯(lián)查詢。
要定義視圖模型,只需要繼承ViewModel,然后設(shè)置viewFields屬性即可。例如下面的例子,我們定義了一個BlogView模型對象,其中包括了Blog模型的id、name、title和User模型的name,以及Category模型的title字段,我們通過創(chuàng)建BlogView模型來快速讀取一個包含了User名稱和類別名稱的Blog記錄(集)。
class BlogViewModel extends ViewModel {
public $viewFields = array(
'Blog'=array('id','name','title'),
'Category'=array('title'='category_name', '_on'='Blog.category_id=Category.id'),
'User'=array('name'='username', '_on'='Blog.user_id=User.id'),
);
}
我們來解釋一下定義的格式代表了什么。
$viewFields 屬性表示視圖模型包含的字段,每個元素定義了某個數(shù)據(jù)表或者模型的字段。
例如:
'Blog'=array('id','name','title');
表示BlogView視圖模型要包含Blog模型中的id、name和title字段屬性,這個其實很容易理解,就和數(shù)據(jù)庫的視圖要包含某個數(shù)據(jù)表的字段一樣。而Blog相當(dāng)于是給Blog模型對應(yīng)的數(shù)據(jù)表定義了一個別名。
默認(rèn)情況下會根據(jù)定義的名稱自動獲取表名,如果希望指定數(shù)據(jù)表,可以使用:
'_table'="test_db.test_table"
如果希望給當(dāng)前數(shù)據(jù)表定義另外的別名,可以使用
'_as'='myBlog'
BlogView視圖模式除了包含Blog模型之外,還包含了Category和User模型,下面的定義:
'Category'=array('title'='category_name');
和上面類似,表示BlogView視圖模型還要包含Category模型的title字段,因為視圖模型里面已經(jīng)存在了一個title字段,所以我們通過
'title'='category_name'
把Category模型的title字段映射為category_name字段,如果有多個字段,可以使用同樣的方式添加??梢酝ㄟ^_on來給視圖模型定義關(guān)聯(lián)查詢條件,例如:
'_on'='Blog.category_id=Category.id'
理解之后,User模型的定義方式同樣也就很容易理解了。
Blog.categoryId=Category.id AND Blog.userId=User.id
最后,我們把視圖模型的定義翻譯成SQL語句就更加容易理解視圖模型的原理了。假設(shè)我們不帶任何其他條件查詢?nèi)康淖侄?,那么查詢的SQL語句就是
Select
Blog.id as id,
Blog.name as name,
Blog.title as title,
Category.title as category_name,
User.name as username
from think_blog Blog JOIN think_category Category JOIN think_user User
where Blog.category_id=Category.id AND Blog.user_id=User.id
視圖模型的定義并不需要先單獨定義其中的模型類,系統(tǒng)會默認(rèn)按照系統(tǒng)的規(guī)則進行數(shù)據(jù)表的定位。如果Blog模型并沒有定義,那么系統(tǒng)會自動根據(jù)當(dāng)前模型的表前綴和后綴來自動獲取對應(yīng)的數(shù)據(jù)表。也就是說,如果我們并沒有定義Blog模型類,那么上面的定義后,系統(tǒng)在進行視圖模型的操作的時候會根據(jù)Blog這個名稱和當(dāng)前的表前綴設(shè)置(假設(shè)為Think_ )獲取到對應(yīng)的數(shù)據(jù)表可能是think_blog。
ThinkPHP還可以支持視圖模型的JOIN類型定義,我們可以把上面的視圖定義改成:
public $viewFields = array(
'Blog'=array('id','name','title','_type'='LEFT'),
'Category'=array('title'='category_name','_on'='Category.id=Blog.category_id','_type'='RIGHT'),
'User'=array('name'='username','_on'='User.id=Blog.user_id'),
);
需要注意的是,這里的_type定義對下一個表有效,因此要注意視圖模型的定義順序。Blog模型的
'_type'='LEFT'
針對的是下一個模型Category而言,通過上面的定義,我們在查詢的時候最終生成的SQL語句就變成:
Select
Blog.id as id,
Blog.name as name,
Blog.title as title,
Category.title as category_name,
User.name as username
from think_blog Blog LEFT JOIN think_category Category ON Blog.category_id=Category.id RIGHT JOIN think_user User ON Blog.user_id=User.id
我們可以在試圖模型里面定義特殊的字段,例如下面的例子定義了一個統(tǒng)計字段
'Category'=array('title'='category_name','COUNT(Blog.id)'='count','_on'='Category.id=Blog.category_id'),
3
視圖查詢
接下來,我們就可以和使用普通模型一樣對視圖模型進行操作了 。
$Model = D("BlogView");
$Model-field('id,name,title,category_name,username')-where('id10')-order('id desc')-select();
看起來和普通的模型操作并沒有什么大的區(qū)別,可以和使用普通模型一樣進行查詢。如果發(fā)現(xiàn)查詢的結(jié)果存在重復(fù)數(shù)據(jù),還可以使用group方法來處理。
$Model-field('id,name,title,category_name,username')-order('id desc')-group('id')-select();
我們可以看到,即使不定義視圖模型,其實我們也可以通過方法來操作,但是顯然非常繁瑣。
$Model = D("Blog");
$Model-table(
'think_blog Blog,
think_category Category,
think_user User')
-field(
'Blog.id,Blog.name,
Blog.title,
Category.title as category_name,
User.name as username')
-order('Blog.id desc')
-where('Blog.category_id=Category.id AND Blog.user_id=User.id')
-select();
而定義了視圖模型之后,所有的字段會進行自動處理,添加表別名和字段別名,從而簡化了原來視圖的復(fù)雜查詢。如果不使用視圖模型,也可以用連貫操作的JOIN方法實現(xiàn)相同的功能。
在創(chuàng)建了自定義模型之后,通常在創(chuàng)建對應(yīng)的欄目時將其設(shè)置成此數(shù)據(jù)模型(比如創(chuàng)建一個“手機”欄目,創(chuàng)建時“模型”選“goods”),然后在欄目首頁列表頁調(diào)用手機欄目下內(nèi)容時使用的標(biāo)簽跟phpcms中調(diào)用文章的原標(biāo)簽使用方法一樣,只是調(diào)用的字段不同而已。
例如,你在goods模型中 價格字段名為price,產(chǎn)品名稱定義為goodsname,那么在調(diào)用列表時可以這么寫(假設(shè)欄目id是10):
{pc:content?action="lists"?catid="10"?num="5"?order="id?desc"}
!--pc標(biāo)簽loop標(biāo)簽等照原樣使用--
ul
{loop?$data?$g}
lia?href="{$g[url]}"{$g[goodsname]}?/aspan{$g[price]}元/span/li
!--差別在于調(diào)用其中字段時使用對應(yīng)自定義字段名稱--
{/loop}
/ul
{/pc}
在內(nèi)容頁中,因為系統(tǒng)會自動對每個字段轉(zhuǎn)化成一個單一變量,以“$字段名”的格式,所以,在內(nèi)容頁中例如你像調(diào)用價格,直接使用 {$price},調(diào)用貨物名直接使用 {$goodsname}即可。
ps:如果您對phpcms的標(biāo)簽不熟悉,可以參考iphpcms里面的教程和phpcms官網(wǎng)的使用手冊。
沒有數(shù)據(jù)表
就不需要操作數(shù)據(jù)庫
你的模型類不要繼承Model類即可
這時候最好不要在數(shù)據(jù)模型上操作,而是在邏輯模型上操作。
也就是說,數(shù)據(jù)模型(Data Model)任然是一個模型對應(yīng)一張表。而在數(shù)據(jù)模型和控制器間,再插入一個邏輯模型(Logic Model),通過邏輯模型(邏輯模型操作多個數(shù)據(jù)模型)完成一些邏輯操作(如下單等等)。
這樣能保證整體架構(gòu)的清晰。
本地如果安裝了mysql,那么一般
地址:localhost
賬號:root
密碼:空
特殊的賬號,密碼,應(yīng)該是會在軟件(mysql)安裝過程中有說明。
沒有安裝的話,那就找個mysql安裝,不會的話,可以直接下載dedecms本地測試包,或者下載個wamp之類的集成php+mysql的軟件安裝下。
1、單擊打開phpstudy軟件,然后單擊mySQL管理器。
2、進入PHPmyadmin登錄界面,默認(rèn)帳號和密碼為root。
3、然后,單擊數(shù)據(jù)庫并輸入所需的數(shù)據(jù)名稱,例如:new,隨機獲取。
4、然后,單擊用戶并單擊“下一步”以添加用戶。
5、填寫用戶名,主機選擇local,密碼設(shè)置為2。一種是自己設(shè)置,另一種是使用系統(tǒng)生成。然后單擊添加用戶。
6、添加成功后,您可以在下面的圖像中看到它,然后單擊編輯權(quán)限。
7、將進入圖形界面,但不在此處設(shè)置權(quán)限。
8、將滾動條滾動到此點,然后選擇剛剛設(shè)置的名稱。
9、將快速進入權(quán)限設(shè)置界面,數(shù)據(jù)和結(jié)構(gòu)選擇,管理全部,然后單擊執(zhí)行。
10、完成上述步驟后,構(gòu)建數(shù)據(jù)庫就完成了。效果如下。
擴展資料
phpStudy一個PHP調(diào)試環(huán)境的程序集成包。該程序包集成最新的Apache+PHP+MySQL+phpMyAdmin+ZendOptimizer,一次性安裝,無須配置即可使用,是非常方便、好用的PHP調(diào)試環(huán)境。該程序不僅包括PHP調(diào)試環(huán)境,還包括了開發(fā)工具、開發(fā)手冊等。
1、MySQL數(shù)據(jù)庫用戶名:root,密碼root,安裝后請重新設(shè)置密碼。
2、本程序支持PHP5.3和PHP5.4一鍵切換,支持系統(tǒng)服務(wù)和非服務(wù)兩種啟動方式,自由切換。改變安裝路徑或拷貝到別的電腦上也可正常運行;即便是運行完再更改路徑也能運行,真正做到無須配置。重寫控制面板更加有效直觀地進行控制程序的啟停。
3、自帶FTP服務(wù)器,支持多用戶,無需再安裝FTP服務(wù)器。自帶網(wǎng)站掛馬監(jiān)視器,隨時記錄文件的修改情況,讓掛馬文件無處可逃。
4、應(yīng)網(wǎng)友的要求制作Nginx版和Lighttpd版。Nginx版為phpfind,Lighttpd版為phpLight。