在上篇文章 使用 Node.js + Express开发服务端 已经学习了NodeJS+Express基本用法,其中API接口返回的数据是假数据,并没有关联数据库查询。在本篇文章中我们将实现基本的数据交互并实现简单的增删改查。如果你还未阅读上篇文章请移步阅读~~~
1. 在上篇文章的项目基础上配置MySQL
确保你电脑中已安装了MySQL环境,我们使用的IDE为Navicat. 新建test数据库并新建一个 Table命名为 user,添加几条数据(用于查询)
Mysql的准备到此就准备完成,接下来是我们本篇教程的重点,怎样使用NodeJS+Express链接MySQL
2. 安装MySQL模块
打开我们刚刚创建的 node_express工程 这里我使用的是Visual Studio Code
接着执行如下命令
npm install 安装mysql依赖
接着我们向工程中添加一个 db 目录 用于存放MySQL配置信息
并在 db 目录总新建一个 DBConfig.js 文件并添加如下内容
//mysql数据库配置
module.exports = {
mysql: {
host:'127.0.0.1',
port:'3306',
user:'root',
password:'这里填写你的mysql的连接密码',
database:'test'
}
}
3. 添加API接口调用SQL语句
紧接着继续在 db目录中添加 Usersql.js 并键入如下内容
var UserSQL = {
insert:'INSERT INTO User(name,gender,age) VALUES(?,?,?)',
queryAll:'SELECT * FROM user',
getUserById:'SELECT * FROM user WHERE id = ? ',
};
module.exports = UserSQL;
Usersql.js 的主要作用是提供增删改查sql语句。
改动routes 目录中的users.js 向外暴露我们操作 User 的API接口。
这里我只在 users.js 中添加一个 addUser/getAll 接口 内容如下
var express = require('express');
var router = express.Router();
//导入MySQL模块
var mysql = require('mysql');
var dbConfig = require('../db/DBConfig');
var userSQL = require('../db/Usersql');
//使用DBConfig.js的配置信息创建一个MySQL连接池
var pool = mysql.createPool(dbConfig.mysql);
//响应一个JSON数据
var responseJSON = function(res, ret){
if(typeof ret === 'undefined'){
res.json({
code:'-200',
msg:'操作失败'
});
}else{
res.json(ret);
}
};
//添加用户
router.get('/addUser', function(req, res, next){
//从连接池获取连接
pool.getConnection(function(err, connection){
//获取前台页面传过来的参数
var param = req.query || req.params;
//建立连接 添加一个用户信息
connection.query(userSQL.insert, [param.name,param.gender,param.age], function(err, result){
if(result){
result = {
code:200,
msg:'添加成功'
};
}
//以json形式,把操作结果返回给前台页面
responseJSON(res, result);
//释放连接
connection.release();
});
});
});
//查询所有用户
//添加用户
router.get('/getAll', function(req, res, next){
//从连接池获取连接
pool.getConnection(function(err, connection){
// //获取前台页面传过来的参数
// var param = req.query || req.params;
//建立连接 添加一个用户信息
connection.query(userSQL.queryAll, function(err, result){
console.log(result);
//以json形式,把操作结果返回给前台页面
responseJSON(res, result);
//释放连接
connection.release();
});
});
});
module.exports = router;
接着重新启动服务器 在浏览器访问,或者用Postman都可以
http://127.0.0.1:3000/users/getAll
http://127.0.0.1:3000/users/addUser?name=helloMysql&gender=1&age=18
{
"code": 200,
"msg": "添加成功"
}
其他sql的语法大家可以自行体验,这里就不在一一赘述,如果你在测试过程中遇到问题欢迎留言交流.