[nodejs] nodejs開發個人博客(四)數據模型


數據庫模型

/model/db.js 數據庫操作類,完成鏈接數據庫和數據庫的增刪查改

查詢表

    /*查詢*/ 
    select:function(tableName,callback,where,field){
        field=field ? field : '*';
        var sql="select "+field+" from "+this.C.DB_PRE+tableName;
        if(where){
            sql+=" where "+where;
        }
        this.db.query(sql,callback);
    }

添加記錄

    /*添加*/
    add:function(tableName,tableData,callback){
         var sql="insert into "+this.C.DB_PRE+tableName;
         var clumn='';
         var value='';
         for(var key in tableData){
               clumn+=","+key;
               value+=",'"+tableData[key]+"'";
          }
         clumns="("+clumn.substr(1)+")";
        values="("+value.substr(1)+")";
        sql=sql+clumns+"values"+values;
        console.log(sql);
        this.db.query(sql,callback);        
    }

 修改記錄

    /*修改*/
    update:function(tableName,tableData,where,callback){
         var sql="update "+this.C.DB_PRE+tableName+" set ";
         var clumns="";
         for(var key in tableData){
               clumns+=","+key+"='"+tableData[key]+"'";
          }
        clumns=clumns.substr(1);

        sql+=clumns+" where "+where;
        console.log(sql);
        this.db.query(sql,callback);        
    }

刪除記錄

    /*刪除*/
    delete:function(tableName,where,callback){
         var sql="delete from "+this.C.DB_PRE+tableName+" where "+where;
        console.log(sql);
        this.db.query(sql,callback);        
    }

業務模型

例如分類模型,/model/category.js

/**
*分類模型
*
*/
module.exports={
    getAllList:function(){
        db.select("category",function(err,list){
            console.log(list);
        });
    },
    /*添加*/
    addCate:function(data){
        db.add("category",data,function(err,list){
            console.log(err);
        });
    },
    /*修改*/
    saveCate:function(data,where){
        db.update("category",data,where,function(err,list){
            console.log(err);
        });
    },
    /*刪除*/
    delCate:function(where){
        db.delete("category",where,function(err,list){
            //console.log(err);
        });
    }
};

控制器

先在公共函數文件增加一個調用模型的方法

    /*實例化模型*/
    model:function(name){
        return require("../model/"+name);
    }

控制器調用業務模型

/**
* 首頁控制器
*/
var router=express.Router();
router.get('/',function(req,res,next){
    F.model("category").getAllList();
    //F.model("category").addCate({"name":"測試"});
    //F.model("category").saveCate({"name":"測試1"},"id=4");
    //F.model("category").delCate("id=4");
    /*渲染模板*/
    res.render("home/index");
});
module.exports=router;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM