微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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返回去,直到最上层,这个是获取数据的关键所在。

原文地址:https://www.jb51.cc/wenti/3279753.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐