史上最全的使用THinkPHP心得和技巧,比手冊還好用,走過路過千萬不要錯過。 使用THinkPHP的心得與技巧總結(一)http://www.jb100.net/html/content-28-475-1.html 使用THinkPHP的心得與技巧總結(二)http://www.jb100.net/html/content-28-477-1.html 使用THinkPHP的心得與技巧總結(三)http://www.jb100.net/html/content-28-479-1.html 使用THinkPHP的心得與技巧總結(四)http://www.jb100.net/html/content-28-248-1.html 這是史上最全的THINKPHP使用技巧總結,比手排還好用,各種用法都有詳細說明,特別適合新手,走過路過千萬不要錯過啊! 約定: 1.所有類別庫檔案必須使用.class.php作為檔案後綴,並且類別名稱和檔案名稱保持一致 2.控制器的類別名稱以Action為後綴 3.模型的類別名稱以Model為後綴,類別名稱第一個字母須大寫 4.資料庫表名全部採用小寫, 如: 資料表名: 前綴_表名 模型類別名稱: 表名Model 註:這裡的表名第一個字母要大寫 建立物件: D('表名') 註:這裡的表名第一個字母要大寫 定義控制器類別 class IndexAction extends Action{ public function show(){ echo '這是新的 show 操作'; } } 然後在瀏覽器裡面輸入 http://localhost/myApp/index.php/Index/show/ 定義模型類別: class 表名Model extends Model{ [//手動定義欄位[可選] protected $fields = array( 'id', 'username', 'email', 'age', '_pk'=>'id', //主鍵 '_autoInc'=>true //是否自增 ) ] } 記錄的修改: $User = D("User") // 實例化 User 物件 $User->find(1) // 找出 id 為 1 的記錄 $User->name = 'ThinkPHP' // 把查找到的記錄的名稱欄位修改為 ThinkPHP $User->save() // 儲存修改的資料 更新特定欄位的值 $User->setField('name','TopThink','id=1') 同 樣可以支援對欄位的操作 $User->setField('score','(score+1)','id=1') 新建記錄,方法1: $User = new UserModel() //實例化 User 物件 $User->字 段名 = 欄位值 //給欄位賦值 $User->add() //新增記錄 新建記錄,方法2: $data['字段名'] = 字段值; //給字段賦值 $User = D('User'); //實例化 User 物件 $User->add($data); //$insertId,Add 方法的回傳值就是最新插入的主鍵值,可以直接取得。 新增多筆記錄: $User = new UserModel() $data[0]['name'] = 'ThinkPHP' $data[0]['email'] = 'sjolzy@chen.com' $data[1]['name'] = '流年' $data[1]['email'] = 'chen@sjolzy.cn' $User>addAll($data) 刪除記錄 $User->find(2) $User->delete() // 刪除查找到的記錄 $User->delete('5,6') // 刪除主鍵為 5、6 的資料 $User->deleteAll() // 刪除查詢出來的所有資料 記錄查詢 $User->getDbFields() //取得目前資料欄位 $User->findAll(); //找所有記錄 $User->findAll('1,3,8') //查詢主鍵為1,3,8的記錄集 $User->count() // 取得記錄數 $User->max('score') // 取得使用者的最大積分 $User->min('score','score>0') // 取得積分大於 0 的使用者的最小積分 $User->avg('欄位名稱') // 取得所有記錄的欄位值的平均值 $User->sum('欄位名稱 ') // 統計欄位值 $User->getN(2,'score>80','score desc') // 傳回符合條件的第 2 筆記錄 $User->getN(2,'score>80','score desc') //還可以取得最後第二筆記錄 $User->first('score>80','score desc') //如果要查詢第一筆記錄,還可以使用 $User->last('score>80','score desc') // 取得最後一筆記錄 $User->top(5,'','score desc') // 取得最高積分的前 5 筆記錄 $User->getBy('name','liu21st') //跟據欄位的欄位值來查詢記錄 $Model = new Model() // 實例化一個 model 物件 沒有對應任何資料表 $Model->query("select * from think_user where status=1") $objrs = $Model->query("select * from think_user where status=1") //自訂查詢 $Model->execute("update think_user set name='thinkPHP' where status=1") //用於更新和寫入資料的 sql 操作,傳回影響的記錄數 $User->startTrans() // 啟動事務 $User->commit() // 提交事務 $User->rollback() // 事務回滾 模板: $this->assign('name',$value); //在 Action 類別裡面使用 assign 方法對模板變數賦值,無論何種變數型別都統一使用 assign 賦值 $this->display() // 輸出模版檔 批量賦值 $array['name'] = 'thinkphp' $array['email'] = 'chen@sjolzy.cn' $array['phone'] = '12335678' $this->assign($array) $this->display() // 呼叫 User 模組的 read 操作模版 $this->display('edit') // 呼叫 User 模組的 edit 操作模版 $this->display('Member:read') // 呼叫 Member 模組的 read 操作模版 $this->display('Xp@User:edit') // 呼叫 Xp 主題的 User 模組的 edit 操作模版 $this->display('../Member/read.html') // 直接指定模版檔案的全名 模板標籤: { } 或 {// 註解內容 } //範本註解 {$user['name']} //輸出陣列變數 {$user:name} //輸出物件的屬性 為了方便模板定義,無論輸出的模板變數是數組還是對象,都可以用下列統一方式輸出: {$user.name} 如果是多維數組或多 層物件屬性的輸出,請使用下面的定義方式: {$user['sub']['name']} {$user:sub:name} 使用函數: 格式:{$varname|function1|function2=arg1,arg2,### } 說明: { 和 $ 符號之間不能有空格 ,後面參數的空格就沒有問題 ###表示模板變數本身的參數位置 。 。 。 。 。 。 。 。 。 。 。 。 。 由於文字太多,這裡只是部分心得和技巧,更多精彩的分享網址如下: 使用THinkPHP的心得與技巧總結(一)http://www.jb100.net/html/content-28-475-1.html 使用THinkPHP的心得與技巧總結(二)http://www.jb100.net/html/content-28-477-1.html 使用THinkPHP的心得與技巧總結(三)http://www.jb100.net/html/content-28-479-1.html 使用THinkPHP的心得與技巧總結(四)http://www.jb100.net/html/content-28-248-1.html |