NodeJS REST API with MySQL and Express
http://www.nodewiz.biz/nodejs-rest-api-with-mysql-and-express/
NPM Modules
- Express
- felixge/node-mysql - Source
Most articles about building a REST API for NodeJS will be based on MongoDB, I'm going to show you how to do it with MySQL.
Implementing the REST API
To implement all the routes required by the API, the full REST API for the node application will be a single file server.js
which consists of the following methods:
Verb | URI | Action |
---|---|---|
GET | /tableName | Retrieve all wines |
GET | /tableName/id | Retrieve the wine with the specified _id |
POST | /tableName | Add a new wine |
PUT | /tableName/id | Update wine with the specified _id |
DELETE | /tableName/id | Delete the wine with the specified _id |
Structure
Require your modules and create a http server based on express framework.
- var express = require('express'),
- app = express(),
- mysql = require('mysql');
- app.listen(3000);
- console.log('Rest Demo Listening on port 3000');
DB Connection
Setup your database and create a pool of connections to MySQL server;
- var express = require('express'),
- app = express(),
- mysql = require('mysql'),
- connectionpool = mysql.createPool({
- host : 'localhost',
- user : 'root',
- password : 'secret',
- database : 'rest_demo'
- });
- app.listen(3000);
- console.log('Rest Demo Listening on port 3000');
Where the configuration uses your host, username, password, and database name of course.
Routes
Your application will only need five REST routes to cover the methods table above.
- var express = require('express'),
- app = express(),
- mysql = require('mysql'),
- connectionpool = mysql.createPool({
- host : 'localhost',
- user : 'root',
- password : 'secret',
- database : 'rest_demo'
- }),
- res.setHeader({ 'Content-Type': 'application/json' });
- app.get('/:table', function(req,res){});
- app.get('/:table/:id', function(req,res){});
- app.post('/:table', function(req,res){});
- app.put('/:table/:id', function(req,res){});
- app.delete('/:table/:id', function(req,res){});
- app.listen(3000);
- console.log('Rest Demo Listening on port 3000');
Each route takes a callback function with request and response objects.
You may also notice we are going to be sending json Content-Type as a response always. I will set it up so that even errors will be responding in json, this is personal preference and you might want to do something else but i see it with AWS, Google, Facebook, ect so figured its generally a good idea.
Connection and Error Handling
We will be getting a connection from our pool, which may have reached its allocated limit and throw an error which needs to be handled.
- var express = require('express'),
- app = express(),
- mysql = require('mysql'),
- connectionpool = mysql.createPool({
- host : 'localhost',
- user : 'root',
- password : 'secret',
- database : 'rest_demo'
- });
- res.setHeader({ 'Content-Type': 'application/json' });
- app.get('/:table', function(req,res){
- connectionpool.getConnection(function(err, connection) {
- if (err) {
- console.error('CONNECTION error: ',err);
- res.statusCode = 503;
- res.send({
- result: 'error',
- err: err.code
- });
- } else {
- // query the database using connection
- }
- });
- });
When we encounter connection errors node.js will log them to the console and our app will respond with http status code 503 Service Unavailable with a mysql server error code.
Querying MySQL
Our routes will define a table name and if required an id, which we will use to build our query and return some json data.
Take a look at fetching the latest 20 rows;
- var express = require('express'),
- app = express(),
- mysql = require('mysql'),
- connectionpool = mysql.createPool({
- host : 'localhost',
- user : 'root',
- password : 'secret',
- database : 'rest_demo'
- });
- app.get('/:table', function(req,res){
- connectionpool.getConnection(function(err, connection) {
- if (err) {
- console.error('CONNECTION error: ',err);
- res.statusCode = 503;
- res.send({
- result: 'error',
- err: err.code
- });
- } else {
- connection.query('SELECT * FROM '+req.params.table+' ORDER BY id DESC LIMIT 20', req.params.id, function(err, rows, fields) {
- if (err) {
- console.error(err);
- res.statusCode = 500;
- res.send({
- result: 'error',
- err: err.code
- });
- }
- res.send({
- result: 'success',
- err: '',
- fields: fields,
- json: rows,
- length: rows.length
- });
- connection.release();
- });
- }
- });
- });
- app.get('/:table/:id', function(req,res){});
- app.post('/:table', function(req,res){});
- app.put('/:table/:id', function(req,res){});
- app.delete('/:table/:id', function(req,res){});
- app.listen(3000);
- console.log('Rest Demo Listening on port 3000');
Other than the error handling (which returns a http code 500) we have responded to the requester with up to 20 rows of data.
They also get the field names and how many rows were returned.
Putting It All Together
Using the above technique we put together our server.js
like so, which comes in at 175 lines in total.
Source GitHub
Note:
Do not use this in production, it is simply a demo.
The main issue is with the varible table name part in the routing, this is a BADidea.
The first thing I would change is encapsulion of each database table in its own js file under a routes
directory, then require the needed js file for each request.
I hope you have enjoyed this demo - please leave your feedback below.
@NodeJS REST API with MySQL and Express http://t.co/NEvSjddwPz#nodewiz @codewiz_biz
— Codewiz.biz (@codewiz_biz) November 20, 2013
NodeJS REST API with MySQL and Express的更多相关文章
- Nodejs学习笔记(五)--- Express安装入门与模版引擎ejs
目录 前言 Express简介和安装 运行第一个基于express框架的Web 模版引擎 ejs express项目结构 express项目分析 app.set(name,value) app.use ...
- Nodejs学习笔记(五)—Express安装入门与模版引擎ejs
前言 前面也学习了一些Node.js的基本入门知道,现在开始进入Web开发的部分: Node.js提供了http模块,这个模块中提供了一些底层接口,可以直接使用,但是直接开发网站那还是太累了,所以ht ...
- 转 用C API 操作MySQL数据库
用C API 操作MySQL数据库 参考MYSQL的帮助文档整理 这里归纳了C API可使用的函数,并在下一节详细介绍了它们.请参见25.2.3节,“C API函数描述”. 函数 描述 mysql_a ...
- .NET框架 - NETCORE + API + EF + MYSQL
.NET框架 - NETCORE + API + EFCORE + MYSQL 1. 新建项目: 本文中使用 框架 .netcore2.2 . 2. 生成项目框架 3 安装MYSQL插件 点击“工具” ...
- nodejs cannot find module 'mysql' 问题分析
在windows平台下,测试nodejs连接mysql数据库. 首先 在控制台中安装mysql依赖包 npm install mysql 安装成功后,mysql依赖包可以在User目录中的node_m ...
- C Mysql API连接Mysql
最近都在查看MYsql C API文档,也遇到了很多问题,下面来简单的做一个总结. mysql多线程问题 mysql多线程处理不好,经常会发生coredump,见使用Mysql出core一文. 单线程 ...
- 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') ...
- nodejs使用sequelize操作mysql实例
sequelize是node操作mysql的一款npm包,包含很多特性:数据库模型映射.事务处理.模型属性校验.关联映射等,花了两天时间学习了下基本的一些操作,特别是关联映射部分的操作,包含1:1.1 ...
随机推荐
- Java集合01----ArrayList的遍历方式及应用
Java集合01----ArrayList的遍历方式及应用 前面已经学习了ArrayList的源代码,为了学以 ...
- 「零秒思考」是个神话,不过这款笔记术你值得拥有zz
今天读完了赤羽雄二的<零秒思考>,作者是一位在麦肯锡公司工作了 14 年的资深顾问.依照作者的说法,「零秒思考」指的是: 瞬间便能认清现状, 瞬间便能整理问题, 瞬间便能考虑出解决办法, ...
- Ubuntu16.04下Django项目的部署
起飞前的准备 # 首先在Ubuntu的当前用户zhang下新建data文件夹,然后在data文件夹下新建你的项目目录root@zhang-virtual-machine:/home/zhang/dat ...
- Spring LDAP
LDAP Spring LDAP 使用 - Sayi像秋天一样优雅 - 开源中国社区 http://docs.spring.io/spring-ldap/docs/current/reference/ ...
- FFmpeg编码详细流程
FFmpeg在编码一个视频的时候的函数调用流程.为了保证结构清晰,其中仅列出了最关键的函数,剔除了其它不是特别重要的函数. 函数背景色 函数在图中以方框的形式表现出来.不同的背景色标志了该函数不同的作 ...
- 从TFS中的现有项目复制一份作为新项目,导致提交的服务器无法加载
解决方案: 1.编辑 .csproj文件,改为自己的名字 2.取消解绑
- 2018.11.23-day26 面向对象(终结)
1.私有成员不能被继承2.装饰器方法--(类方法&静态方法)3.装饰器--property方法4.反射
- 九度OJ 1125:大整数的因子 (大数运算)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:974 解决:494 题目描述: 已知正整数k满足2<=k<=9,现给出长度最大为30位的十进制非负整数c,求所有能整除c的k. ...
- ElasticSearch(八)关于document的一些知识点
先查看一条数据: GET /ecommerce/product/5 { "_index" : "ecommerce", "_type" : ...
- Ubuntu安装搜狗输入法笔记
1.移除ibus sudo apt-get purge ibussudo apt-get autoremove 2.安装fcitx sudo apt-get install fcitx 3.安装搜狗输 ...