Express整合MySQL搭建后端服务

之前写过springboot整合mysql,但自己是搞前端的,所以还是想着用Js去写后端,于是就有了Express与Mysql整合的想法。做的时候没用express生成器,一点一点写的,毕竟只是学习嘛,没那么讲究。废话不多说,下面进入正题。

以下都是基于 node 10.15.0版本所做的

创建一个空文件夹并进入,执行 npm init -y 创建一个node项目。

npm init -y

此时文件夹下会生成一个package.json文件。
里面有个main属性,对应的值就是你要运行的js文件,默认叫index,我的给它改成了app,如下:

"main": "app.js"

安装依赖 express、 mysql

npm i express
npm i mysql

在根目录下,创建一个app.js文件,一个controller目录,一个service目录,一个static目录。

在app.js里引入express,使用express里的json等中间件来处理json数据等等,最后监听指定的端口号,如下:

const express = require('express')
const app = express()
const userController = require('./controller/user-controller/index')

app.use(express.json())
app.use(express.urlencoded())

app.use('/user', userController)

app.listen('9090', () => {
	console.log('NodeJs后端服务器启动成功')
})

app.use(‘/user’, userController),这个用来处理对应的路由。接下来咋弄,直接放代码了。

控制层:

const express = require('express')
const router = express.Router()
const userService = require('../../service/user-service/index')

router.get('/listUser', (req, res) => {
	userService.listUser(req, res)
})

module.exports = router

它调用了service层,service层如下:

const mysql = require('../../static/js/mysql/index')

module.exports.listUser = (req, res) => {
	let sql = 'select * from user'
	let value = []
	mysql.query(sql, value, (row) => {
		res.json(row)
	})
}

它调用了mysql,mysql代码如下:

const mysql = require('mysql')
const util = require('../util/inex')

const pool = mysql.createPool({
	host: '127.0.0.1',
	port: '3306',
	user: 'root',
	password: 'password',
	database: '你要连接的数据名字',
	connectionLimit: 50, //用于指定连接池中最大的链接数,默认属性值为10.
	queueLimit: 3 //用于指定允许挂起的最大连接数,如果挂起的连接数超过该数值,就会立即抛出一个错误,默认属性值为0.代表不允许被挂起的最大连接数。
})

module.exports.query = (sql, value, callback) => {
	pool.getConnection((err, connection) => {
		if (err) {
			console.log('数据库连接失败')
			pool.releaseConnection() //释放链接
			let error = {
				code: '500',
				message: '数据库连接失败'
			}
			callback(error)
		} else {
			connection.query(sql, value, (err, row) => {
				if (err) {
					console.log('sql语句执行失败,没有找到指定的结果')
					connection.release() //释放链接
					let error = {
						code: '500',
						message: 'Sql语句执行失败,没有找到指定的结果'
					}
					callback(error)
				} else {
					connection.release()
					if (row instanceof Array) {
						let response = {
							code: '200',
							date: util.toHump(row)
						}
						callback(response)
					} else {
						let response = {
							code: '200',
							data: []
						}
						callback(response)
					}
				}
			})
		}
	})
}

里面有个toHump方法,我表里的字段使用小写接下划线的,但是返回给前台的时候想转换成驼峰的,所以写了个工具方法,如下:

// 下划线转驼峰
module.exports.toHump = (array) => {
	let toHump = (key) => {
		return key.replace(/\_(\w)/g, function (all, letter) {
			return letter.toUpperCase();
		})
	}
	let tempArray = []
	for (let i of array) {
		let obj = {}
		for (let j of Object.keys(i)) {
			obj[toHump(j)] = i[j]
		}
		tempArray.push(obj)
	}
	return tempArray
}

最后的最后,运行app.js文件,直接 node app.js (后缀可以省略)。运行完毕,去浏览器访问接口,就能看到相应的数据了。

顺带提一下,这有个缺点。就是每改一次代码就要重启一次,所以我用nodemon启动。首先全局安装nodemon,我装的2.0.0版本,最新版本在用的时候好像会报错,不知道啥原因所致(难道node版本低了?我之前用16.16.0的版本貌似也出错,郁闷啊。。。)。安装好之后,直接 nodemon app.js就可以了。

全局安装 nodemon,如下:

npm i nodemon@2.0.0 -g

特此记录!