1.连接步骤学习
首先需要安装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()
const sql = 'select * from myschool';
connection.query(sql, (err, result) => {
console.log(result);
})
5)关闭连接
connection.end()
2.应用
1)在项目中我们建立数据库相关文件,并且将上述基本步骤写入
2)引入
查询年级的接口我们可以试一下查询功能,引入方法,然后将原先的死数据替换掉,传入sql语句和掉函数,按照年级去查询:
3)错误排查
查了一些文章,感觉是MysqL安装有问题,我先解决问题,完了来回来完善文章。(请直接看3)
4)参数查询sql
结果如下,这时已经按条件完成了筛选
5)用在项目
主要是如何把数据返回出来
下面我们在处理方法的地方将promise返回出去,并使用then去接收一下:
下面我们来看一下结果,出现了404的情况:
我想应该也需要用then去接收一下,同理继续返回promise到最上层:
再执行一下查询年级的接口,已经正确返回了数据,至此已经完成接口的连接了;
3.debug
错误 提示后,开始以为是MysqL安装有问题,重新下载了MysqL,还是会有这个问题,然后继续百度找到了解决方法:
按照上述方法执行后,数据总是拿不到
发现在MysqL.js中执行最后关闭了MysqL,而请求中是不要关闭的,所以注掉之后,可以正常运行了,这些数据证实我数据库中的模拟数据,下面回到上一节4)继续看代码吧。
4.总结
1)可能会出现数据库无法连接的问题,很多原因,可能是配置没写对,可能数据库环境变量问题,也可能就是我遇到的问题,解决方法在上文中
由于MysqL版本的问题造成连接失败。MysqL8 之前的版本中加密规则是MysqL_native_password,而在MysqL8之后,加密规则是caching_sha2_password;
2)连接后将数据返回,因为实在回调函数中,所以首先优化为promise方式(不是必要),然后将promise返回去,直到最上层,这个是获取数据的关键所在。