首先需要安装mysql模块: npm install --save mysql
1)下面就是代码实现,简单先写一下步骤:
const mysql = require('mysql');
2)// 创建连接的对象
- const connection = mysql.createConnection({
- host: 'localhost',
- user: 'root',
- password: '1001',
- port: '3306',
- database: 'school'
- })
写的都是mysql的连接信息,这里就要求我们先装上mysql,就不详细介绍了,网上都有安装教程,界面如下所示,图片上有一些基本增删改查语句大家可以跟着学习一下:
3)打开数据连接
connection.connect()
4)写sql语句进行查询
- const sql = 'select * from myschool';
- connection.query(sql, (err, result) => {
- console.log(result);
- })
5)关闭连接
connection.end()
查询年级的接口我们可以试一下查询功能,引入方法,然后将原先的死数据替换掉,传入sql语句和掉函数,按照年级去查询:
遇到了一个错误如下,排查完之后,定位错误在sql文件中
查了一些文章,感觉是mysql安装有问题,我先解决问题,完了来回来完善文章。(请直接看3)
结果如下,这时已经按条件完成了筛选
主要是如何把数据返回出来
先用promise优化一下mysql文件
下面我们在处理方法的地方将promise返回出去,并使用then去接收一下:
下面我们来看一下结果,出现了404的情况:
我想应该也需要用then去接收一下,同理继续返回promise到最上层:
再执行一下查询年级的接口,已经正确返回了数据,至此已经完成接口的连接了;
错误 提示后,开始以为是mysql安装有问题,重新下载了mysql,还是会有这个问题,然后继续百度找到了解决方法:
按照上述方法执行后,数据总是拿不到
发现在mysql.js中执行最后关闭了mysql,而请求中是不要关闭的,所以注掉之后,可以正常运行了,这些数据证实我数据库中的模拟数据,下面回到上一节4)继续看代码吧。
1)可能会出现数据库无法连接的问题,很多原因,可能是配置没写对,可能数据库环境变量问题,也可能就是我遇到的问题,解决方法在上文中
由于mysql版本的问题造成连接失败。mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password;
2)连接后将数据返回,因为实在回调函数中,所以首先优化为promise方式(不是必要),然后将promise返回去,直到最上层,这个是获取数据的关键所在。