1.控制器創(chuàng)建原則:
基本原則:根據(jù)功能,原則上一個功能項對應控制器中的一個動作
可能多個功能共享一個動作添加和修改比較接近,根據(jù)條件來選擇添加還是修改
可能需要輔助方法完成一個動作
基本原則:根據(jù)功能,按照數(shù)據(jù)表結構進行劃分控制器類
基本原則,項目包含多個不同用戶角色的功能,如果不區(qū)分模塊,可能會導致控制器重名,影響代碼閱讀,按照不同角色功能劃分不同模塊
是否有必要創(chuàng)建模塊
控制器文件如何分類
控制器動作如何制定
2.視圖文件的架設
靜態(tài)資源文件
組成:圖片 css JavaScript
文件目錄:public/子目錄
布局文件
組成:頁面頭部,尾部,面包屑,正文
目錄:模塊目錄/view/
視圖文件
一般原則:控制器中的一個方法對應一個視圖文件
3.數(shù)據(jù)庫模型基本使用
連接數(shù)據(jù)庫
使用配置文件
傳入?yún)?shù)形式
實例化數(shù)據(jù)庫操作對象
使用new Model()創(chuàng)建
使用M()函數(shù)創(chuàng)建
執(zhí)行SQL原生查詢
Query()方法
Dump()函數(shù)測試結果
4.數(shù)據(jù)庫基本操作
字符串查詢
$table = M('tableName');
$results = $table -> where('id > 3')->select();
關聯(lián)數(shù)組查詢
$condition['id'] = array('neq','3');
$condition['uid'] = array('neq','1');
$results = $table -> where($conditon) -> select();
魔術方法查詢
$results = $table -> getById('1');//只能獲取指定條件的第一條記錄
統(tǒng)計數(shù)據(jù)
$count = $table -> count();//統(tǒng)計表中數(shù)據(jù)
$count = $table ->max('id');
limit
$limit = $table -> limit(3) -> select();//前三條記錄
$limit = $table -> limit(2,2) -> select();//第三條記錄開始查詢兩個
order排序
$order = $table -> order('id desc') ->select();//id降序排列
創(chuàng)建和插入數(shù)據(jù)
Create():在內(nèi)存中創(chuàng)建數(shù)據(jù),不寫入數(shù)據(jù)庫,過濾掉無效字段(表中沒有的字段)
工作流程:1.獲取數(shù)據(jù)(POST參數(shù)或者用戶傳入的數(shù)據(jù))2.進行數(shù)據(jù)校驗3.把傳入的數(shù)據(jù)放到當前對象的data屬性中
參數(shù):1.若沒有參數(shù),表示插入$_POST[]數(shù)據(jù)2.可以傳入關聯(lián)數(shù)組數(shù)據(jù)3.可以傳入標準對象數(shù)據(jù)
Model::MODEL_INSERT Model::MODELUPDATE
返回值:創(chuàng)建好的數(shù)據(jù)對象組
可以直接為Model對象添加屬性或修改屬性,以實現(xiàn)添加內(nèi)存數(shù)據(jù)的目的
Data():基本同create(),不進行數(shù)據(jù)校驗
Add():把內(nèi)存中的數(shù)據(jù)插入到表中
1沒有參數(shù),直接使用MODEL對象的data屬性(create()和data()方法返回)
2附加條件
3是否覆蓋標識(是否覆蓋已經(jīng)存在的主鍵數(shù)據(jù))
4可以直接過濾掉數(shù)據(jù)表中不存在的字段
5直接使用add(),不會進行數(shù)據(jù)校驗
//寫入數(shù)據(jù)前進行校驗
if($this -> create($data))
{
return $this-> add();
}
讀取數(shù)據(jù)
Select():1不傳參查詢表中所有記錄2.傳一個參數(shù)select(1)主鍵為1的記錄3.select(1,3,5)返回主鍵為135的記錄4傳入false返回當前查詢的語句
Find():查詢一條記錄,不傳入?yún)?shù)獲取第一條記錄,find(1)返回主鍵為1的記錄
getField():只傳入一個參數(shù),獲取第一條記錄的值
where條件:1傳入字符串 2傳入數(shù)組或者對象,可以過濾掉非法字符。
limit():limit(1)1.獲取指定條件的1條記錄 limit(2,2)獲取從第一個參數(shù)開始的2條記錄
order():按照指定字段對記錄進行排序,單字段排序和多字段排序
刪除數(shù)據(jù):刪除成功返回刪除的個數(shù),失敗返回false
$db = M(‘msgs’);
$results = $db –> where(‘id = 1’)-> delete();//刪除id為1的記錄
$results = $db –> where(‘1’)-> delete();//刪除所有記錄
$results = $db -> delete();//不傳參數(shù)返回false
$results = $db -> delete('1,3,5')//刪除主鍵為135的記錄
修改數(shù)據(jù):更新指定條件的數(shù)據(jù)
$data['name'] = "張三";
$results = $db -> where('id = 1') -> save($data)
若傳參,表示更新后要滿足的效果
若不傳參,表示使用當前數(shù)據(jù)表操作對象data屬性中的記錄
更新條件,可以使用where顯示指明更新條件,若無更新條件,save()參數(shù)中的記錄包含主鍵,更新主鍵對應的記錄,否則不更新。更新成功返回更新的記錄數(shù),更新失敗,返回false
setField:更新個別字段的值
setInc加 setDec減
5.模型操作類
作用:MVC分離相對徹底,邏輯清晰,適合分工合作,方便實現(xiàn)一些特性的效果(過濾,驗證,自動完成)
創(chuàng)建模型類:
文件名:數(shù)據(jù)表名Model.class.php
目錄:模塊/model/目錄
類名:class數(shù)據(jù)表名Model extends Model
可選屬性:tablePrefixtableName trueTableName dbName _validate(自動驗證規(guī)則) _auto(自動完成規(guī)則)
添加方法用來實現(xiàn)業(yè)務邏輯
使用:new方法 D()函數(shù)
6.ActivRecord
表映射到類,記錄映射到對象
ORM模型:對象關系映射模型
7.session處理
初始化:無需手動調(diào)用,除非有特殊需要的時候
設置值:session(鍵,值);
獲取值:session(鍵);
刪除值:session(鍵,null);
判斷值是否存在:session(?鍵);
模板中使用session:判斷session狀態(tài) 輸出session值
控制器中輸出session dump($_SESSION);
present標簽用于判斷某個變量是否已經(jīng)定義
<present name="Think.session.loginedUser"> 歡迎您,{$Think.session.loginedUser}! | <a href="/user/logout">注銷</a> <else /> 您尚未登錄(<a href='/home/user/login/'>登錄</a>) 還沒有用戶名(<a href='/home/user/register/'>注冊</a>) </present> 8.分頁 頁面跳轉 <input type="submit" onclick="window.location.href='/home/msg/addmsg/';" value="添加一個新討論話題"> 分頁本質(zhì)是:limit查詢 sql語句:select * from msg offset size//從offset開始的size條記錄 分頁鏈接 /home/msg/index/page/1另外有需要云服務器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
本文名稱:thinkphp筆記二-創(chuàng)新互聯(lián)
當前地址:http://sd-ha.com/article32/djjdpc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、面包屑導航、網(wǎng)站內(nèi)鏈、定制開發(fā)、網(wǎng)站收錄、外貿(mào)網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容