天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

PHP實現MVC開發得最簡單的方法――模型

昨天群里有人說使用MVC讓程序多了很多數據庫操作,使得性能下降,這著實讓我吃了一驚。MVC只是一種框架,與數據庫操作沒有任何關系。MVC只是提供一種清晰的編程開發模式,只要你處理的好,是不可能多處很多無謂的數據庫操作的。如果一個MVC讓一個程序員在不知情的情況下多出了很多數據庫操作就絕對不是一個很好的MVC架構。我覺得MVC只要提供一個簡單的開發框架就行了,沒有必要集成很多庫類,庫類最好能讓程序員自己選擇去使用。 
    我自己這個MVC框架的目的就只是實現一個簡單的MVC流程,其他的大家具體情況具體添加。做到真正的小巧、靈活、高效! 
    前幾周我寫了兩篇文章,《php實現MVC開發得最簡單的方法――視圖及模版技術》、《php實現MVC開發得最簡單的方法――單點入口》。今天具體說說如何實現MVC的模型。 
    我沒有深入研究過MVC的理論,對我個人來說,模型就是一個數據庫的封裝,調用模型的方法,你可以得到相應的數據,但實現的細節程序員不需要關心。在實際開發中,很可能一個數據庫的表就對應一個模型。比如說一個用戶信息表userinfo,對應就有一個模型user,通過調用模型user的add()方法你就可以向數據庫添加一條數據,通過select()你就可以實現查詢,通過update就能實現更新。同時模型應該是和具體的數據庫類型無關的,無論你使用的mysql,oracle還是sql server。同時我不推薦在WEB開發中使用ROR,復雜的多表查詢使用SQL語言是多么方便和快捷的事情,而且性能更好。如果一個程序員連SQL的知識都沒有,我不認為他是一個合格的程序員。所以,我在我的模型里面,提供了一個query的方法來實現直接的SQL查詢。 
     下面是模型的一個大概結果。不是完整代碼,完整代碼請見demo包。 

復制代碼 代碼如下:
<?   
class module{   

   var $mysql;//數據庫操作類,可以是mysql,oracle,sql等等   

   var $tbname;//模型對應的表名稱   

   var $debug=false;//是否是調試模式   

   function module($tbname,$db=''){}//構造函數   

   function _setDebug($debug=true){}//開啟或者關閉調試模式   

   function add($row,$tbname=''){}//新增加一條記錄   

   function query($strsql){}//直接查詢sql語句   

   function count($where='',$tbname=''){ }//計數統計   

   function select($where='',$tbname=''){}//查詢   

   function delete($where='',$tbname=''){}//刪除滿足條件的一個記錄   

   function update($set,$where,$tbname=''){}//更新指定記錄   

   function detail($where,$tbname=''){}//詳細顯示一條記錄   
}   
?>  


    在這個模型里面,我是使用數組和數據庫的字段來對應的。早期的phpBEAN里面使用了對象來對應。但后來感覺這種方法在php中不好,而且增加了很多無謂的類。使用數組更加方便,效果更好(php中的數組的確是個好東西,相對Java來說好太多了)。 

    在下面的demo中,我使用了mysql數據庫來演示,其中數據庫操作類改自我原來的一個庫類,詳細請看《修改下以前的庫類,php5->php4》。 

    下面,詳細講解使用demo。^_^ 
     在原來的的包的index.php里面增加 

<?  
require_once(SITE_PATH.'/libs/phpbean.class.php');  
require_once(SITE_PATH.'/libs/mysql.class.php');  
$phpbean=new phpbean();  
global $phpbean;  

$mysql=new mysql("localhost","****","****","52site");   
$phpbean->register('db',$mysql);  
unset($mysql);  
?>  

   這段代碼主要是把MYSQL注冊到注冊器里面,關于注冊器的使用的原理,可以看我翻譯的兩篇文章。 
 然后新建一個mysqlController.class.php文件,代碼如下: 

<?  
/**  
  * MVC演示demo  
  * 僅僅實現最基本的MVC功能,不包含安全處理,數據過濾,及其他優化措施。  
  * @author:feifengxlq  
  * @since:2007-1-24  
  * @copyright http://www.phpobject.NET/blog/  
*/  
class mysqlController  
{  
    var $module;  

    function mysqlController(){  
        require_once(SITE_PATH.'/libs/module.class.php');  
        $this->module=new module('52site_siteinfo');//52site_siteinfo為表名稱  
        $this->module->query("set names 'gb2312'");//如果是MYSQL5請加上這句  
    }  

    function indexAction(){  
        print_r($this->module->select());//這樣實現了讀取數據  
    }  
}  
?>  

     上面首先是控制器的構造函數里面,加入一個模型。然后在indexAction里面調用模型的方法來顯示數據。這樣就實現了最簡單的查詢列表。你可以通過這個地址來查看你的結果http://path/to/yoursite/mv... 
     以后我會寫一個具體的demo來說明如何使用模型的其他方法,比如說查詢、更新、增加、分頁列表、多表連查等等。

php技術PHP實現MVC開發得最簡單的方法――模型,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久伊人男人的天堂网站 | 99久久99久久免费精品蜜桃 | 人妻无码AV中文系列 | 国产成人免费在线观看 | BL全肉多攻NP高H | 一本色道久久88加勒比—综合 | 国产一区二区无码蜜芽精品 | 成人高清网站 | 把腿张开再深点好爽宝贝 | 亚洲伊人精品综合在合线 | 亚洲国产精品久久无套麻豆 | 欧美手机在线 | 日韩AV成人无码久久精品老人 | 日韩人妻无码专区一本二本 | AV一区AV久久AV无码 | 亚洲伊人成综合人影院 | 恋夜影院支持安卓视频美女 | 午夜男女爽爽羞羞影院在线观看 | 午夜精品久久久内射近拍高清 | 亚洲中字幕永久在线观看 | 我要色导航 | 日韩一区二区三区免费体验 | 大香伊人久久精品一区二区 | 男欢女爱免费视频 | qvod伦理片| 好湿好紧水多AAAAA片秀人网 | 欧美GV肉片视频免费观看 | 亚洲AV无码偷拍在线观看 | 人妻激情综合久久久久蜜桃 | 91热久久免费频精品动漫99 | 床伴在线观看免费高清完整泰剧第四集 | 征服丝袜旗袍人妻 | 亚洲人成电影网站 | 韩国女人高潮嗷嗷叫视频 | 无码乱人伦一区二区亚洲一 | 国产亚洲欧美在线观看三区 | 国内精品九九视频 | qvod电影在线观看 | JIZZ19学生第一次 | zxfuli午夜福利在线 | 精品亚洲欧美中文字幕在线看 |