码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • nodeJs读取mysql数据库的数据


    1.连接步骤学习

    首先需要安装mysql模块: npm install --save mysql

    1)下面就是代码实现,简单先写一下步骤:

    const mysql = require('mysql');

    2)// 创建连接的对象

    1. const connection = mysql.createConnection({
    2. host: 'localhost',
    3. user: 'root',
    4. password: '1001',
    5. port: '3306',
    6. database: 'school'
    7. })

    写的都是mysql的连接信息,这里就要求我们先装上mysql,就不详细介绍了,网上都有安装教程,界面如下所示,图片上有一些基本增删改查语句大家可以跟着学习一下:

    3)打开数据连接

    connection.connect()

     4)写sql语句进行查询

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

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

  • 相关阅读:
    Python基础——文件的基本操作
    JScript的编写、调试
    MySQL中最左匹配相关实践总结
    CG-26 土壤热通量传感器 浅谈热通量的工作原理
    Linux入门
    SpringBoot 整合 RabbitMQ
    【课程】SP Module2 辅音和元音的声学
    云服务器安装 redis
    模型评估指标
    【C++模板】typename关键字的用法
  • 原文地址:https://blog.csdn.net/q553866469/article/details/126513653
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号