简单实现 nodejs koa2 mysql 增删改查 制作接口
1.首先 在电脑上安装 nodejs (此处略过)
2.全局安装 koa2 (这里使用的淘宝镜像cnpm,有兴趣的同学可以自行搜索下)
cnpm install koa-generator -g
3.创建项目
koa2 code(code 是项目名)
4.(cd code) 然后 安装依赖
cnpm install
5.(cd code 进入code目录 ) 然后 启动项目
cnpm start code 该操作修改代码后,需重启生效 cnpm run dev 该操作修改代码后,刷新浏览器生效
6. node 连接数据库
cnpm install mysql --save
7.1 开始增删改查 目录结构
db.js 是数据库的配置
代码如下: //数据库配置文件
const MYSQL_CONFIG = {
host : '你的数据库地址', // 可以是本地地址,也可以设置成远程地址
user : '你的数据库账户', // 我这边是mysql,一般都是root
password : '你的数据库密码',
database : '你连接的数据库名'
};
module.exports = MYSQL_CONFIG;
dbSQL.js 里面是sql语句
代码如下: const QUERY_SQL = `select * from t_user`;
const INSERT_SQL = `INSERT INTO t_user SET ?`;
const UPDATE_SQL = `UPDATE t_user SET username=? WHERE id=?`;
const DELETE_SQL = `DELETE FROM t_user WHERE id=?`; module.exports = { QUERY_SQL, INSERT_SQL, UPDATE_SQL, DELETE_SQL };
dbPool.js 里面是创建连接池,并编写查询方法
代码如下: const mysql = require('mysql')
const MYSQL_CONFIG = require('./db'); let pools = {}; // 创建连接池
//判断是否存在连接池不用每次都创建
if (!pools.hasOwnProperty('data')) {
pools['data'] = mysql.createPool(MYSQL_CONFIG);
} // 查询
// sql 是sql语句
// values 是sql语句中的具体值
// sql values 可查看官方文档 https://github.com/mysqljs/mysql#performing-queries
const query = (sql, values) => {
return new Promise((resolve, reject) => {
//初始化连接池
pools['data'].getConnection((err, connection) => {
if (err) {
console.log(err,'数据库连接失败');
}
else{
console.log('数据库连接成功');
//操作数据库
connection.query(sql, values, (err, results) => {
if (err) {
reject(err);
} else {
connection.release();
resolve({
status: 200,
results
});
}
});
}
})
});
} module.exports = { query };
dataOperation.js 是数据库的增删改查操作,目前是放在router里面的,最好是分离出来,方便维护
代码如下: const router = require('koa-router')()
const { query } = require('./../config/dbPool');
const { QUERY_SQL, INSERT_SQL, UPDATE_SQL, DELETE_SQL } = require('./../config/dbSQL'); //查询
// 测试时可简单创建 string: name, number: id, 自增主键id
router.get('/search', async ctx => {
const data = await query(QUERY_SQL);
ctx.body = {
data,
};
}); // 插入
router.post('/save', async ctx => {
const res = ctx.request.body;
const { username = '', realname = '', password = '' } = res;
if(username && realname) {
const queryData = {
username,
realname,
password,
};
const data = await query(INSERT_SQL, queryData);
if(data && data.status && data.status === 200) {
ctx.body = {
status: 200,
msg: "操作成功",
};
} else {
ctx.body = data;
}
}
}); //更新
router.post('/update', async ctx => {
const res = ctx.request.body;
const { username = '', id= 1 } = res;
if(username && id) {
const queryData = [username, id];
const data = await query(UPDATE_SQL, queryData);
if(data && data.status && data.status === 200) {
ctx.body = {
status: 200,
msg: "操作成功",
};
} else {
ctx.body = data;
}
}
}); //根据主键id 删除
router.del('/delete', async ctx => {
const res = ctx.request.body;
const { id } = res;
if(id) {
const queryData = [id];
const data = await query(DELETE_SQL, queryData);
if(data && data.status && data.status === 200) {
ctx.body = {
status: 200,
msg: "操作成功",
};
} else {
ctx.body = data;
}
}
}); module.exports = router;
接下来是测试接口 这里使用的是postman
查询
新增
修改
删除
接口制作完成 之后 ,要部署到腾讯云服务器 可以参考我这篇文章:
把 nodejs koa2 制作的后台接口 部署到 腾讯云服务器
简单实现 nodejs koa2 mysql 增删改查 制作接口的更多相关文章
- nodejs+express+mysql 增删改查
之前,一直使用的是nodejs+thinkjs来完成自己所需的项目需求,而对于nodejs中另外一中应用框架express却了解的少之又少,这两天就简单的了解了一下如何使用express来做一些数据库 ...
- nodejs+express+mysql 增删改查(二)
1.最早一篇关于express框架简单的增删改查文章,http://www.cnblogs.com/zhengyeye/p/nodejs.html#3947308:意外走红博客园,无奈自己之前一直没有 ...
- Nodejs操作MySQL - 增删改查
先安装npm模块项目 npm init 安装mysql npm install mysql --save Nodejs 连接msyql // 导入mysql const mysql = require ...
- 最简单的jsp+servlet的增删改查代码
package ceet.ac.cn.dao; import java.sql.Connection; import java.sql.PreparedStatement; import java.s ...
- MySQL—增删改查,分组,连表,limit,union,alter,排序,去重
MySQL增删改查 在表格的增删改查中,查的内容是最多的,包括group by ,join,limit,union,alter,排序都是服务于查的 #sql语句数据行操作补充 #增加: #insert ...
- PHP MySql增删改查
mysql_connect()连接数据库 mysql_select_db选择数据库 mysql_fetch_assoc()获取结果集 mysql_query()执行sql语句 实例如下: <?p ...
- mysql增删改查练习
Mysql增删改查sql语句练习 关于数据库的一些操作: 进入mysql 命令行: mysql -uroot –p 查看所有数据库: show databases; 创建数据库: create dat ...
- 四种简单的sql语句(增删改查语句)
四种简单的sql语句(增删改查语句) 一.插入语句 insert into [table] ([column],[column],[column]) values(?,?,?) 二.删除语句 dele ...
- Django学习之mysql增删改查
上节介绍了如何使用命令行操作mysql增删改查,现在介绍如何使用python管理mysql 使用pip 下载完mysql后,mysql会以pymysql模块的形式存储在pycharm的包文件里.我们通 ...
随机推荐
- python 12篇 mock接口之flask模块
一.使用pip install flask按照flask模块. import flask,json # 轻量级web开发框架 server = flask.Flask(__name__) @serve ...
- 不用SCRAPY也可以应用selector
在PY文件中: from scrapy.selector import Selectorfrom scrapy.http import HtmlResponse url="https://m ...
- C语言:位域详解
有些数据在存储时并不需要占用一个完整的字节,只需要占用一个或几个二进制位即可.例如开关只有通电和断电两种状态,用 0 和 1 表示足以,也就是用一个二进位.正是基于这种考虑,C语言又提供了一种叫做位域 ...
- matlab——插值与拟合
@ 目录 前言 一.拟合 1.定义 2.三种判别准则 3.最小二乘法 (1)一般形式 (2)常用函数 (3)matlab实现 二.插值 1.定义 2.方法 (1)分段线性插值 (2)拉格朗日插值多项式 ...
- yoyogo v1.7.6 增强程序优雅退出和K8s Readiness检查
YoyoGo (Go语言框架)一个简单.轻量.快速.基于依赖注入的微服务框架( web .grpc ),支持Nacos/Consoul/Etcd/Eureka/k8s /Apollo等 . 本次更新增 ...
- 一次搞懂JavaScript对象
索引 目录 索引 1. 对象与类 2.对象使用 2.1 语法 2.2 属性 3.对象特性 4.对象的创建 4.1 字面量 4.2 工厂函数 4.3 构造函数 4.4 class类 4.5 对象与单例模 ...
- synchronized锁定类方法、volatile关键字及其他(八)
同步静态方法 synchronized还可以应用在静态方法上,如果这么写,则代表的是对当前.java文件对应的Class类加锁.看一下例子,注意一下printC()并不是一个静态方法: public ...
- ffmpeg 任意文件读取漏洞/SSRF漏洞 (CVE-2016-1897/CVE-2016-1898)
影响版本 在FFMpeg2.X poc http://192.168.49.2:8000/?name={%25%20for%20c%20in%20[].__class__.__base__.__sub ...
- ;~ 小部分AutoHotkey源代码片段测试模板2019年10月9日.ahk
;~ 小部分AutoHotkey源代码片段测试模板2019年10月9日.ahk ;~ 此脚本用于测试执行一行或多行AHK脚本源代码的效果;~ 此脚本最后修改于2019年9月22日20时03分;~ 把此 ...
- git 提代码时的相关命令,Mark一下
以前用命令提代码都是复制粘贴,现在换了工作后,特别是回退代码的命令又忘了,去网上查了好久,心累.特此Mark一下 1. 打patch: 1.1 git diff >> ljh.patch ...