程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> yii model層操作總結

yii model層操作總結

編輯:關於PHP編程

yii model層操作總結


yii model層操作屬性和方法總結。

tableName – 設置Model所對應的表名,例如:

public function tableName(){return 'gshop_order_ext';}

rules – 設置Model裡各字段的驗證規則

relations – 設置關聯規則

attributeLabels – 設置各字段的別名

safeAttributes – 設置可以修改屬性的字段

beforeValidate和afterValidate – 字段驗證前和驗證後執行的函數, 需要返回true值

beforeSave和afterSave – 記錄存儲前和存儲後執行的函數, 需要返回true值

其次, Yii裡的ORM使用的是AR, 有幾個主要的操作, 分別是:

save – 操作數據

update – 修改數據

delete – 刪除數據

validate – 驗證數據

讀取記錄時, 有以下幾個方法:

findByPk – 通過主鍵查找記錄, 結果為單條記錄

findByAttribute – 通過屬性查找記錄, 結果為單條記錄

findAllByAttributes – 通過屬性查找數據, 結果為記錄集

findAll – 通過CDbCriteria對象查找數據, 結果為記錄集 *

查找方法接收的參數有2種, 沒有星號的, 接受數組作為參數, 有星號的接收CDbCriteria對象作為參數, 使用對象的時候, 可以提供更多的查找條件, 下面給出一個實例:

$criteria = new CDbCriteria; // 創建CDbCriteria對象
$criteria->condition = 'title LIKE %' . 'php' . '%'; // 設置查詢條件
$criteria->order = 'createdTime DESC'; // 設置排序條件
$criteria->limit = 10; // 限定記錄的條數
$criteria->select = 'id,title,content'; // 設置結果所包含的字段

$articles = Article::model()->findAll($criteria); //結果為數組, 其中每個元素為記錄對象

再次, Yii對關聯數據默認采用LazyLoad的加載形式, 即需要時才讀取. 這樣, 當我們不需要關聯數據的時候, Yii是不會幫我們去讀取的, 大大加快了反應的速度. 但是也有一些時候, 我們是需要關聯數據的, 比如說讀取文章的時候, 我們是需要文章所屬的分類的, 如果使用LazyLoad的形式, 就要有多少條, 查詢多少次, 效率非常低下, 這時就需要EagerLoad了, 即一次把關聯表的數據全部讀出.

比如:

$articles = Article::model()->with('category')->findAll();

使用with將關聯表的數據一次全部讀出. 關聯表的設置在Model裡的relation裡設置.

比如:

public function relations() {
       return array(
             'category' => array(self::BELONGS_TO, 'Category', 'categoryId'),
       );
}

非常的清晰明了。

您可能感興趣的文章

  • Yii framework框架之模塊開發分析
  • Yii框架Yiiapp()的理解
  • yii 數據庫添加,修改,刪除相關操作總結
  • yii數據庫查詢操作總結
  • Yii CDbCriteria的常用方法總結
  • Yii 獲取當前控制器名稱和動作名稱
  • Yii使用PHPExcel導入Excel文件的方法
  • Yii 動作方法技巧

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved