前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[nodejs] nodejs开发个人博客(四)数据模型

[nodejs] nodejs开发个人博客(四)数据模型

作者头像
唯一Chat
发布2019-09-10 11:06:54
4470
发布2019-09-10 11:06:54
举报
文章被收录于专栏:陶士涵的菜地陶士涵的菜地

数据库模型

/model/db.js 数据库操作类,完成链接数据库和数据库的增删查改

查询表

代码语言:javascript
复制
    /*查询*/ 
    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);
    }

添加记录

代码语言:javascript
复制
    /*添加*/
    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);        
    }

修改记录

代码语言:javascript
复制
    /*修改*/
    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);        
    }

删除记录

代码语言:javascript
复制
    /*删除*/
    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

代码语言:javascript
复制
/**
*分类模型
*
*/
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);
        });
    }
};

控制器

先在公共函数文件增加一个调用模型的方法

代码语言:javascript
复制
    /*实例化模型*/
    model:function(name){
        return require("../model/"+name);
    }

控制器调用业务模型

代码语言:javascript
复制
/**
* 首页控制器
*/
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;
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-03-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 数据库模型
  • 业务模型
  • 控制器
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档