1 首先引入的上篇node 链接mysql 里面的js

var connect = require('./nodemysql.js');

2 定义常量

const customerSQL = {

    queryAll: function(dbname, callback, obj) { //obj查找的条件 若没有全部返回
        var where = ''
        if (obj == undefined) {
            where = ''
        } else {
            var s = ' WHERE '
            for (var i in obj) {
                s += i + '="' + obj[i] + '" and '
            }
            where = s.substring(0, s.lastIndexOf(' and'))
        }
        var sql = 'SELECT * FROM ' + dbname + where;
        console.log(sql)
        connect.query(sql, function(err, result) {
                if (err) {
                    console.log('[SELECT ERROR] - ', err.message);
                    callback({ code: 0, mes: err.message })
                    return;
                }
                callback({ code: 1, res: result })
                return;
            })
            // console.log(result);

    },
    insert: function(dbname, callback, obj) { //obj插入的数据
        var sql = 'insert into ' + dbname + ' set ?'
        console.log(sql)

        connect.query(sql, obj, function(err, result) {
            if (err) {
                console.log('[insert ERROR] - ', err.message);
                callback({ code: 0, mes: err.message })
                return;
            }
            callback({ code: 1, res: result })
                //             {
                //   "code": 1,
                //   "res": {
                //     "fieldCount": 0,
                //     "affectedRows": 1,
                //     "insertId": 16,//插入行的id
                //     "serverStatus": 2,
                //     "warningCount": 0,
                //     "message": "",
                //     "protocol41": true,
                //     "changedRows": 0
                //   }
                // }
            return;
        })
    },
    update: function(dbname, callback, arr) { //[{},{}] 第一个obj是要改的数据 第二个obj是查询条件
        var where = ''
        var obj = arr[1]
        if (obj == undefined) {
            callback({ code: 0, mes: 'no key' });
            return;
        } else {
            var s = ' where '
            for (var i in obj) {
                s += i + '="' + obj[i] + '" and '
            }
            where = s.substring(0, s.lastIndexOf(' and'));
        }
        var sql = 'update ' + dbname + ' set ?' + where;

        connect.query(sql, arr[0], function(err, result) {
            if (err) {
                console.log('[update ERROR] - ', err.message);
                callback({ code: 0, mes: err.message })
                return;
            }
            callback({ code: 1, res: result });
            //                 {
            //   "code": 1,
            //   "res": {
            //     "fieldCount": 0,
            //     "affectedRows": 1,
            //     "insertId": 0,
            //     "serverStatus": 34,
            //     "warningCount": 0,
            //     "message": "(Rows matched: 1  Changed: 1  Warnings: 0",
            //     "protocol41": true,
            //     "changedRows": 1 //被改变的行数
            //   }
            // }
            return;
        })

    },
    delete: function(dbname, callback, obj) {
        var where = ''
        if (obj == undefined) {
            callback({ code: 0, mes: 'no key' });
            return;
        } else {
            var s = ' WHERE '
            for (var i in obj) {
                s += i + '="' + obj[i] + '" and '
            }
            where = s.substring(0, s.lastIndexOf(' and'))
        }
        var sql = 'delete  from ' + dbname + where;

        connect.query(sql, function(err, result) {
                if (err) {
                    console.log('[delete ERROR] - ', err.message);
                    callback({ code: 0, mes: err.message })
                    return;
                }
                callback({ code: 1, res: result });
                //                 {
                //   "code": 1,
                //   "res": {
                //     "fieldCount": 0,
                //     "affectedRows": 1,//受影响的行数
                //     "insertId": 0,
                //     "serverStatus": 2,
                //     "warningCount": 0,
                //     "message": "",
                //     "protocol41": true,
                //     "changedRows": 0
                //   }
                // }
                return;
            })
            // console.log(result);

    },

};

 3 、输出常量和connet

module.exports = { customerSQL, connect };

4、 使用

查询:

var { customerSQL, connect } = require('./customersql.js');
app.get('/bayid', function(req, res) {

    var i = req.query.id ? { id: req.query.id } : undefined
    var show = function(result) {
        res.send(result);
    }
    customerSQL.queryAll('fruit', show, i)

});

 修改:

router.post('/setname', function(req, res, next) {
    var ss = req.body.name
    if (ss == undefined) {
        res.json({
            code: 0,
            message: '修改错误,没有key'
        })
        return
    };
    var nickname = {
        name: ss
    };
    var show = function(result) {
        console.log(result)

        var r = {}
        if (result.code == 0) {
            res.json({
                code: 0,
                message: '修改失败'
            })
        } else {
            res.json({
                code: 1,
                message: '修改成功'
            })
        }

    };
    customerSQL.update('user', show, [nickname, { id: 69 }])

});

  

 

自封装node 的简单增删改查的更多相关文章

  1. ado.net的简单数据库操作(三)——简单增删改查的实际应用

    果然,在犯困的时候就该写写博客,写博客就不困了,哈哈! 上篇我记录了自己的SqlHelper的开发过程,今天记录一下如何使用这个sqlhelper书写一个具有简单增删改查的小实例啦. 实例描述:在数据 ...

  2. Redis:五种数据类型的简单增删改查

    Redis简单增删改查例子 例一:字符串的增删改查 #增加一个key为ay_key的值 127.0.0.1:6379> set ay_key "ay" OK #查询ay_ke ...

  3. node 后台使用增删改查(4)

    无论node还是java增删改查都是一样的原理,变得是配合框架使用时候有简便方法而已. 这里我接着上一篇开始讲,使用同一个数据库(数据库创建)这里必须创建了数据库 优化:为了维护方便这里我们把sql语 ...

  4. 国产化之路-统信UOS + Nginx + Asp.Net MVC + EF Core 3.1 + 达梦DM8实现简单增删改查操作

    专题目录 国产化之路-统信UOS操作系统安装 国产化之路-国产操作系统安装.net core 3.1 sdk 国产化之路-安装WEB服务器 国产化之路-安装达梦DM8数据库 国产化之路-统信UOS + ...

  5. Mybatis实现简单增删改查

    Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...

  6. 04-springboot整合elasticsearch初识-简单增删改查及复杂排序,分页,聚合操作

        前面大概了解了一下elasticsearch的数据存储和数据的查询.现在学习一下,es的复杂操作.     官网相关文档地址:https://www.elastic.co/guide/en/e ...

  7. linq的简单增删改查

    Linq高集成化的数据访问类,它会自动映射数据库结构,将表名完整映射成为类名,将列名完整映射成字段名数据库数据访问,能大大减少代码量.(反正最后结果就是不用写ado.Net那一套增删改查,有一套封装好 ...

  8. Android_ADB 常用 shell命令 和 sqlite3 简单增删改查

    今天学习了一个ADB的常用命令.接下来简单使用几个常用ADB shell 命令. 首先我们得明白什么是adb.exe ADB -Android Debug Bridge, 是 Android sdk ...

  9. MyBatis之二:简单增删改查

    这一篇在上一篇的基础上简单讲解如何进行增删改查操作. 一.在mybatis的配置文件conf.xml中注册xml与注解映射 <!-- 注册映射文件 --> <mappers> ...

随机推荐

  1. Centos7中docker开启远程访问

    在作为docker远程服务的centos7机器中配置: 1.在/usr/lib/systemd/system/docker.service,配置远程访问.主要是在[Service]这个部分,加上下面两 ...

  2. 关于Linux MongoDB的安装

    前一篇博文讲解了如何安装与配置MongoDB的windows版,本篇博文接着上一篇讲解如何在Linux系统中安装与配置MongoDB,为了演示,我问同事要了它的云服务器用于演示,当然我自己也有,但是已 ...

  3. grid布局学习二之子元素(项目)

    /* grid-column-start属性:左边框所在的垂直网格线 grid-column-end属性:右边框所在的垂直网格线 grid-row-start属性:上边框所在的水平网格线 grid-r ...

  4. SSD报告 - QRadar远程命令执行

    SSD报告 - QRadar远程命令执行 漏洞摘要 QRadar中的多个漏洞允许远程未经身份验证的攻击者使产品执行任意命令.每个漏洞本身并不像链接那么强大 - 这允许用户从未经身份验证的访问更改为经过 ...

  5. Java学习笔记47(JDBC、SQL注入攻击原理以及解决)

    JDBC:java的数据库连接 JDBC本质是一套API,由开发公司定义的类和接口 这里使用mysql驱动,是一套类库,实现了接口 驱动程序类库,实现接口重写方法,由驱动程序操作数据库 JDBC操作步 ...

  6. Python Socket请求网站获取数据

     Python Socket请求网站获取数据 ---阻塞 I/O     ->收快递,快递如果不到,就干不了其他的活 ---非阻塞I/0 ->收快递,不断的去问,有没有送到,有没有送到,. ...

  7. [EXP]CVE-2018-2628 Weblogic GetShell Exploit

    漏洞简介 漏洞威胁:RCE--远程代码执行 漏洞组件:weblogic 影响版本:10.3.6.0.12.1.3.0.12.2.1.2.12.2.1.3 代码: # -*- coding: utf-8 ...

  8. Xshell连接ESXI方法

    第一步.ESXI打开ssh功能按住F2进入设置如下图: 第二步.输入密码 第三步.选择Troubleshooting Options 回车 第四步.选择Enable SSH 这里只介绍了一种方式打开E ...

  9. Spring Boot + Spring Cloud 实现权限管理系统 后端篇(二十二):链路追踪(Sleuth、Zipkin)

    在线演示 演示地址:http://139.196.87.48:9002/kitty 用户名:admin 密码:admin 技术背景 在微服务架构中,随着业务发展,系统拆分导致系统调用链路愈发复杂,一个 ...

  10. Modifying namespace in XML document programmatically

    Modifying namespace in XML document programmatically static XElement stripNS(XElement root) { return ...