nodeJs读取mysql数据库的数据

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()

 4)写sql语句进行查询

const sql = 'select * from myschool';
connection.query(sql, (err, result) => {
    console.log(result);
})

5)关闭连接

connection.end()

2.应用

1)在项目中我们建立数据库相关文件,并且将上述基本步骤写入 

2)引入

查询年级的接口我们可以试一下查询功能,引入方法,然后将原先的死数据替换掉,传入sql语句和掉函数,按照年级去查询

3)错误排查

遇到了一个错误如下,排查完之后,定位错误sql文件

查了一些文章,感觉是MysqL安装有问题,我先解决问题,完了来回来完善文章。(请直接看3)

4)参数查询sql

结果如下,这时已经按条件完成了筛选

 5)用在项目

主要是如何把数据返回出来

先用promise优化一下MysqL文件

下面我们在处理方法的地方将promise返回出去,并使用then去接收一下:

下面我们来看一下结果,出现了404的情况:

 我想应该也需要用then去接收一下,同理继续返回promise到最上层:

 

再执行一下查询年级的接口,已经正确返回了数据,至此已经完成接口的连接了;

3.debug

错误 提示后,开始以为是MysqL安装有问题,重新下载了MysqL,还是会有这个问题,然后继续百度找到了解决方法

解决Navicat连接不上MySql服务器报错:Client does not support authentication protocol requested by server; conside_小李睡醒了的博客-CSDN博客解决Navicat连接不上MySql服务器报错:Client does not support authentication protocol requested by server; consider upgrading MySQL client1.问题原因2.解决问题1.问题原因通过相关问题查阅,发现是由于navicat版本的问题造成连接失败。mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_passwordhttps://blog.csdn.net/weixin_43111077/article/details/108811949

 按照上述方法执行后,数据总是拿不到

发现在MysqL.js中执行最后关闭MysqL,而请求中是不要关闭的,所以注掉之后,可以正常运行了,这些数据证实我数据库中的模拟数据,下面回到上一节4)继续看代码吧。

 4.总结

1)可能会出现数据库无法连接的问题,很多原因,可能是配置没写对,可能数据库环境变量问题,也可能就是我遇到的问题,解决方法在上文中

由于MysqL版本的问题造成连接失败。MysqL8 之前的版本中加密规则是MysqL_native_password,而在MysqL8之后,加密规则是caching_sha2_password;

2)连接后将数据返回,因为实在回调函数中,所以首先优化为promise方式(不是必要),然后将promise返回去,直到最上层,这个是获取数据的关键所在。

相关文章

显卡天梯图2024最新版,显卡是电脑进行图形处理的重要设备,...
初始化电脑时出现问题怎么办,可以使用win系统的安装介质,连...
todesk远程开机怎么设置,两台电脑要在同一局域网内,然后需...
油猴谷歌插件怎么安装,可以通过谷歌应用商店进行安装,需要...
虚拟内存这个名词想必很多人都听说过,我们在使用电脑的时候...