自封装node 的简单增删改查
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 的简单增删改查的更多相关文章
- ado.net的简单数据库操作(三)——简单增删改查的实际应用
果然,在犯困的时候就该写写博客,写博客就不困了,哈哈! 上篇我记录了自己的SqlHelper的开发过程,今天记录一下如何使用这个sqlhelper书写一个具有简单增删改查的小实例啦. 实例描述:在数据 ...
- Redis:五种数据类型的简单增删改查
Redis简单增删改查例子 例一:字符串的增删改查 #增加一个key为ay_key的值 127.0.0.1:6379> set ay_key "ay" OK #查询ay_ke ...
- node 后台使用增删改查(4)
无论node还是java增删改查都是一样的原理,变得是配合框架使用时候有简便方法而已. 这里我接着上一篇开始讲,使用同一个数据库(数据库创建)这里必须创建了数据库 优化:为了维护方便这里我们把sql语 ...
- 国产化之路-统信UOS + Nginx + Asp.Net MVC + EF Core 3.1 + 达梦DM8实现简单增删改查操作
专题目录 国产化之路-统信UOS操作系统安装 国产化之路-国产操作系统安装.net core 3.1 sdk 国产化之路-安装WEB服务器 国产化之路-安装达梦DM8数据库 国产化之路-统信UOS + ...
- Mybatis实现简单增删改查
Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...
- 04-springboot整合elasticsearch初识-简单增删改查及复杂排序,分页,聚合操作
前面大概了解了一下elasticsearch的数据存储和数据的查询.现在学习一下,es的复杂操作. 官网相关文档地址:https://www.elastic.co/guide/en/e ...
- linq的简单增删改查
Linq高集成化的数据访问类,它会自动映射数据库结构,将表名完整映射成为类名,将列名完整映射成字段名数据库数据访问,能大大减少代码量.(反正最后结果就是不用写ado.Net那一套增删改查,有一套封装好 ...
- Android_ADB 常用 shell命令 和 sqlite3 简单增删改查
今天学习了一个ADB的常用命令.接下来简单使用几个常用ADB shell 命令. 首先我们得明白什么是adb.exe ADB -Android Debug Bridge, 是 Android sdk ...
- MyBatis之二:简单增删改查
这一篇在上一篇的基础上简单讲解如何进行增删改查操作. 一.在mybatis的配置文件conf.xml中注册xml与注解映射 <!-- 注册映射文件 --> <mappers> ...
随机推荐
- java 项目的路径详情
title: 项目下的路径问题tags:grammar_cjkRuby: true--- 在javaee的项目中,存取文件,解析xml和properties文件,以及项目中的文件,都需要获取路径,常用 ...
- Android开发 - 更"聪明"的申请权限方式
在Android6.0以后,很多权限需要动态申请,只有在用户点同意后,我们才能使用对应API,因此,正确申请权限就显得很重要. 常用方式 通常我们使用这种方式来判断权限状态: private stat ...
- Java学习笔记30(集合框架四:List接口)
List接口继承自Collection接口 具有重要的三大特点: 1.有序集合:存入和取出的顺序一致 2.此接口的用户可以对列表中每个元素插入位置精确的控制:可以通过索引操作 3.可以存储重复元素 L ...
- Docker优势
设计,开发 ---> 测试 ----> 部署,运行 代码+运行环境 ---> 镜像 image 环境一致,资源占用少 自动化平台 Docker image的制作很重要
- iptables概述
[参考文章]:iptables详解-朱双印个人日志 [参考文章]:linux iptables详解--个人笔记 [参考文章]:iptables详解--转 [参考文章]:linux下IPTABLES配置 ...
- C++ vector 容器浅析
一.什么是vector? 向量(Vector)是一个封装了动态大小数组的顺序容器(Sequence Container).跟任意其它类型容器一样,它能够存放各种类型的对象.可以简单的认为,向量是一个能 ...
- 关于文件命名,你必须要知道的(浏览器报错:net::ERR_BLOCKED_BY_CLIENT)
坑爹的,今天在写完页面,用各个浏览器测试的时候,火狐.谷歌都是正常的,QQ浏览器出幺蛾子了,在使用兼容模式的时候页面正常,使用急速模式的时候部分页面正常,点击跳转到其他页面的时候就出错了,打开控制台一 ...
- HoloLens开发手记 - 使用Visual Studio Using Visual Studio
不论你是否使用DirectX或Unity来开发全息应用,你都会使用Visual Studio 2015来进行调试和部署应用.在本部分,你将会学习以下内容: 如何通过Visual Studio将你的应用 ...
- nohup后台执行
由于使用nohup时,会自动将输出写入nohup.out文件中,如果文件很大的话,nohup.out就会不停的增大,这是我们不希望看到的,因此,可以利用/dev/null来解决这个问题. nohup ...
- C# Command命令(行为型模式)+队列 实现事务,带异步命令重试机制和生命周期
一.简介 耦合是软件不能抵御变变化的根本性原因,不仅实体对象与实体对象之间有耦合关系(如创建性设计模式存在的原因),对象和行为之间也存在耦合关系. 二.实战 1.常规开发中,我们经常会在控制器中或者M ...