1 回答

TA貢獻(xiàn)1878條經(jīng)驗(yàn) 獲得超4個(gè)贊
、創(chuàng)建一個(gè)基礎(chǔ)模型:實(shí)例化一個(gè)系統(tǒng)自帶的數(shù)據(jù)庫操作類
Test.Model.class.php
class TestModel extends Model{
}
UserAction.class.php
function test(){
$test=M('test');//表示實(shí)例化的是自帶的Model類,并且傳入test值表示操作的是test表
//等同于$test=new TestModel();
$test=$test->select();
print_r($test);//輸出test表中所有數(shù)據(jù)
}
2、實(shí)例化一個(gè)自定義模型
如果數(shù)據(jù)庫操作比較復(fù)雜,就需要在自定義的Model類中添加一些自定義的數(shù)據(jù)庫操作方法
UserModel.class.php
class UserModel extends Model{
function pyj(){
echo 'pengyanjie';
//其它的一些數(shù)據(jù)庫操作方法
}
}
UserAction.class.php
function user(){
$user=D('User');//實(shí)例化自定義的數(shù)據(jù)庫操作類
//等同于$user=new UserModel();
$user->pyj();//調(diào)用User模型中的pyj方法
}
或者,你需要實(shí)例化一個(gè)表,同時(shí)呢,實(shí)例化一個(gè)自己寫的自定義的數(shù)據(jù)庫操作類
function love(){
$love=M('test','UserModel');
//$love=new UserModel('test');
$list=$love->select();
dump($list);
$love->pyj();
}
3、實(shí)例化一個(gè)用戶模型
UserAction.class.php
function user(){
$user=new UserModel();//等同于$user=D('User');
$list=$user->select();
dump($list);
echo $user->aa();
}
UserModel.class.php
該類名user與表名user相對應(yīng),所以在UserAction中實(shí)例化這個(gè)模型的時(shí)候就不需要再額外的傳表名了
class UserModel extends Model{
function aa(){
echo 'pengyanjie';
}
}
這個(gè)第三種實(shí)例化模型方法與第二種的區(qū)別在于:在你的業(yè)務(wù)邏輯當(dāng)中,通常情況下會有一些公共的業(yè)務(wù)邏輯,那你用第二種M('表名','模型名');如M('user','CommonModel')會更方便;
第三種實(shí)例化模型方法適于于針對所操作表的更加復(fù)雜的業(yè)務(wù)邏輯,但是它不需要使用到公共業(yè)務(wù)邏輯。(它的業(yè)務(wù)邏輯,針對用戶表,它是唯一的,并且不需要在其它模型當(dāng)中使用)。
4、實(shí)例化一個(gè)空模型,它并不知道你要實(shí)例化操作時(shí)用到的是哪張表。
$user=new Model();//等價(jià)與$user=M();
$list=$user->query('select * from think_user'); //使用傳統(tǒng)的sql語句的方式,如果這樣的話,就必須要加表前綴
dump($list);
附:$user=new UserModel();與$user=D('user');的區(qū)別:
(1)、D方法可以自動檢測模型類,不存在時(shí),它會拋出一個(gè)異常。同時(shí)對于已實(shí)例化過的模型,不會去重復(fù)實(shí)例化。默認(rèn)的D方法,只能應(yīng)用于當(dāng)前項(xiàng)目下面的模型。
(2)、如果說,我這是前臺應(yīng)用,但是我想實(shí)例化后臺項(xiàng)目的模型可以用D搞定。
$user=D('admin','user');//會去自動找admin分組下的user模型類
或者
$user=D('admin.user');
- 1 回答
- 0 關(guān)注
- 741 瀏覽
添加回答
舉報(bào)