nodejs 中使用 mysql 实现 crud
首先要使用 mysql 就必须要安装
npm install mysql
然后封装 sql 函数
const mySql = require('mysql');
let connection ;
let insert, update, deletes, select;
insert = update = deletes = select = (condition, callback) => {
// insert into 表名(`name`,`age`) values('张三',12),('李四',13)
// select * from 表名 where id=1 and name='张三'
// update 表名 set name='张三' where id=1
// delete from 表名 where id=1
connection.query(condition, (err, data) => {
if (err) throw err;
callback && callback(data);
});
};
// 或使用占位符的方式
insert = (sql, values, callback) => {
// 单条数据插入
// sql:'insert into 表名 set ?'
// values:{name: '张三', age:14}
connection.query(sql, values, (err, data) => {
if (err) throw err;
callback && callback(data);
});
// 多条数据插入
// sql:'insert into 表名(`name`,`age`) values ?'
// values:[['张三', 18],['李四', 19],['王五', 20]]
connection.query(sql, [values], (err, data) => {
if (err) throw err;
callback && callback(data);
});
}
update = (sql, values, callback) => {
// 注意:mysql 没有批量 update 的方法,得使用循环来单个修改
// 更新单条数据
// sql:'update 表名 set name=?,age=? where id=?'
// values:['张三', 14, 1]
connection.query(sql, values, (err, data) => {
if (err) throw err;
callback && callback(data);
});
// 更新全部数据
// sql:'update 表名 set name=?'
// values:['张三']
connection.query(sql, values, (err, data) => {
if(err) throw err;
callback && callback(data);
})
};
select = (sql, values, callback) => {
// 多条件查询
// sql:'select * from 表名 where name = ? and age = ?'
// 或 sql:'select * from 表名 where name = ? or age = ?'
// values:['张三', 12]
connection.query(sql, values, (err, data) => {
if (err) throw err;
callback && callback(data);
});
// 同条件限定查询
// sql:'select * from 表名 where id in (?)'
// values:[1,2,3,4]
connection.query(sql, [values], (err, data)=>{
if(err) throw err;
callback && callback(data)
})
};
deletes = (sql, values, callback) =>{
// 删除一条
// sql:'delete from 表名 where id=?'
// values:[1]
connnection.query(sql, values, (err, data)=>{
if(err) throw err;
callback && callback(data);
})
// 删除多条
// sql:'delete from 表名 where id in (?)'
// values:[1,2,3]
connection.query(sql, [values], (err, data) => {
if(err) throw err;
callback && callback(data)
});
};
const connectionStart = callback => {
connection = mySql.createConnection({
host: 'localhost',
user: 'root',
password: '',
database: 'bms-test-back'
});
connection.connect(err => {
if (err) return console.log('connectSql fail:' + err);
callback && callback();
});
};
const connectionEnd = () => connection.end();
module.exports = {
insert,
update,
deletes,
select,
connectionStart,
connectionEnd
}
最后要在哪个 js 文件中使用,引入即可
nodejs 中使用 mysql 实现 crud的更多相关文章
- 关于nodejs中遇到mysql默认8小时连接断开机制的终极简单解决方案
由于mysql默认8小时连接无访问,就会断开.为此查了一下资料,有同种比较简单的解决方案: 1. 增加 MySQL 的 wait_timeout 属性的值. 修改 /etc/mysql/my.cnf文 ...
- nodejs中mysql用法
nodejs也算是一篇脚本了我们来看nodejs如何使用mysql数据库了有了它们两组合感觉还是非常的不错哦,下面一起来看nodejs中使用mysql数据库的示例,希望能够帮助到各位. <scr ...
- nodejs中如何使用mysql数据库[node-mysql翻译]
nodejs中如何使用mysql数据库 db-mysql因为node-waf: not found已经不能使用,可以使用mysql代替. 本文主要是[node-mysql]: https://www. ...
- nodejs中如何连接mysql
nodejs中如何连接mysql,下面给出一个小Demo. 第一步安装mysql模块npm install mysql 第二步导入mysql模块var mysql = require('mysql') ...
- 【原】无脑操作:express + MySQL 实现CRUD
基于node.js的web开发框架express简单方便,很多项目中都在使用.这里结合MySQL数据库,实现最简单的CRUD操作. 开发环境: IDE:WebStorm DB:MySQL ------ ...
- 详细讲解nodejs中使用socket的私聊的方式
详细讲解nodejs中使用socket的私聊的方式 在上一次我使用nodejs+express+socketio+mysql搭建聊天室,这基本上就是从socket.io的官网上的一份教程式复制学习,然 ...
- 使用nodejs+express+socketio+mysql搭建聊天室
使用nodejs+express+socketio+mysql搭建聊天室 nodejs相关的资料已经很多了,我也是学习中吧,于是把socket的教程看了下,学着做了个聊天室,然后加入简单的操作mysq ...
- nodejs remote链接mysql数据库总结
nodejs链接远端mysql,这个折腾了一个上午才搞定.本以为,直接使用就OK了,但是发现不行,后来查阅各种资料后,终于找到了方法. nodejs链接远端数据库主要分为几个步骤: 1)安装node- ...
- 第68节:Java中的MYSQL运用从小白到大牛
第68节:Java中的MYSQL运用从小白到大牛 前言 学习java必备要求,学会运用!!! 常见关系化数据库 BootStrap是轻量级开发响应式页面的框架,全局css组件,js插件.栅格系统是将页 ...
随机推荐
- node.js的初级使用
node.js的初级使用 作为一个全栈开发员怎么能不会node.js了?至少得会用node搭载环境吧!话不多说直接开干! 一.下载与安装: 官网:http://nodejs.cn/ 中文文档:http ...
- RESTful API 学习【第1篇】
一. 什么是RESTful REST与技术无关,代表的是一种软件架构风格,REST是Representational State Transfer的简称,中文翻译为“表征状态转移” REST从资源的角 ...
- Ubuntu 18.04 nvidia driver 390.48 安装 TensorFlow 1.12.0 和 PyTorch 1.0.0 详细教程
最近要在个人台式机上搭建TensorFlow和PyTorch运行环境,期间遇到了一些问题.这里就把解决的过程记录下来,同时也可以作为安装上述环境的过程记录. 如果没有遇到类似的问题,想直接从零安装上述 ...
- zk strom 本地环境启动命令
bin/zkServer.sh statusbin/zkServer.sh startbin/storm nimbus &bin/storm ui &bin/storm drpc &a ...
- 8.1.1 Connection 对象
Connect是sqllite3模块中最基本的也是最重要的一个类,其主要方法如下表所示: 方法 说明 execute(sql[,parameters]) 执行一条SQL语句 executemany(s ...
- SFTP文件上传下载
http://www.cnblogs.com/longyg/archive/2012/06/25/2556576.html (转载)
- JavaSE 学习笔记之多态(七)
多 态:函数本身就具备多态性,某一种事物有不同的具体的体现. 体现:父类引用或者接口的引用指向了自己的子类对象.//Animal a = new Cat(); 多态的好处:提高了程序的扩展性. 多态的 ...
- 联赛前集训日记Day1
考试 炸的凄惨 T1 显然要高精搞一下,然而我的$DFS$竟然比我的$O(n^{2})$递推快 T2 欧拉路径的题,很不可做的样子,就没敢费时间打 T3 $DFS$枚举可过,然而我太蠢 GG 刷题 改 ...
- SSM框架下实现导入功能
何叫导入?简单说,导入就是把excel表格里的数据插入到数据库里.我这里做的是支持.xls和.xlsx格式. 因为是自己做案例记录,那些jar包什么的就不细说了,主要讲实现和步骤,看代码: 先在你的项 ...
- 2018你应该了解这些.NET面试题
2018年准备要找.NET开发相关工作的你准备好了吗,下面是小编准备的一些.NET相关的面试题,来阅读一下,也许对你有帮助哦~ 1. 谈谈你对MVC和三层架构的理解. MVC即模型.视图.控制器,模型 ...