NodeJs 连接本地 mySql 数据库获取数据

news2024/12/31 1:29:51
写在前面

今天把 nodejs 连接本地数据库的坑简单的踩一下,为后续写接口做个铺垫

安装 mySql (mac举例子)

安装地址

  • 安装完成大概这个样子,起动起来就行
    https://dev.mysql.com/downloads/mysql/
安装本地数据库连接工具(navicat举例子)

安装地址

  • 连接之后 新建一个 Table 的数据 如图
    在这里插入图片描述
本地启动 nodejs
// 生成一个 package.json 文件 便于后面管理插件
npm init -y

// 安装 express
npm i express

// 安装 mySql

npm i mysql

实现连接数据库的代码
const express = require('express');
const mysql = require('mysql');

const serve = express();
const port = 3000;

// TODO: 创建数据库链接
const db = mysql.createConnection({
	host:"localhost",
	user:"root",
	password : "5211314Code",
	database:"sys",
});

// TODO: 测试 test 请求接口
serve.get("/test",(req,res)=>{
	res.status(403);
	res.send("访问的资源不存在");
});

// TODO: 获取用户数据请求接口
serve.get("/getlist",(req,res)=>{
	db.query("select * from userinfos",(err,result)=>{
		if(err){
			res.status(500).send("数据库访问失败");
		}else{
			res.status(200).send(JSON.stringify(result));
		}
	})
});

// TODO: 启动监听
serve.listen(port,()=>{
	console.log("serve is running...");
});

启动测试
node linkSql.js

在这里插入图片描述

浏览器中访问测试
http://localhost:3000/test

在这里插入图片描述

http://localhost:3000/getlist

在这里插入图片描述

可能遇到的问题
  • 问题1

在这里插入图片描述问题原因:

这里是因为mysql8.0 以上的严格加密模式,nodejs 的是普通模式,这里即使密码是对的,也无法访问
解决方案:

// 终端打开 mysql
mysql -u root -p
// 输入密码之后 执行命令
alter user 'root'@'localhost' identified with mysql_native_password by '*******(你自己的数据库链接密码)';

在这里插入图片描述

  • 问题 2

在这里插入图片描述
问题原因:

本地电脑安装 mysql 之后没有配置环境变量导致
解决方案:

// 找到本地安装的 mysql
sudo find / -name  mysql

在这里插入图片描述

// 打开本地的配置文件
open ~/.bash_profile
// 添加下面的文件到该文件中
export PATH=${PATH}:/usr/local/mysql/bin // 根据自己的实际路径进行配置
// 刷新 配置文件
source ~/.bash_profile

// 避免后续手动更新配置文件(可以不进行)
open ~/.zshrc 
// 添加下面的内容到该文件中
source ~/.bash_profile // 该命令添加到.zshrc 文件中 保存即可
  • 问题 3:

在这里插入图片描述
问题原因:

这里是因为 express 更新之后 语法变了,我这里用的之前的语法,大家以最新的语法为准,按照我上面的写法是不会有这个问题的

总结

这里使用 nodejs 作为后端开发的是可以用到的,这里是一个入门基础的过程,主要是展示链接本地数据库的一个步骤,后续遇到相关问题可以作为参考使用!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1843519.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RISC_CPU模块的调试

代码: cpu.v include "clk_gen.v" include "accum.v" include "adr.v" include "alu.v" include "machine.v" include "counter.v" include "machinectl.v" include "register.v&quo…

探索Linux命令的新利器:linux-command

在Linux操作系统中,熟练掌握各种命令是成为一名高效开发者或管理员的关键。然而,即使是经验丰富的用户,有时也会遇到命令用法不熟悉或者记忆模糊的情况。这时,一个功能强大的命令搜索工具就显得格外重要。最近在逛github的时候正好…

Qemu虚拟机在线迁移到VMware

libvirt版本:libvirt-10.0.0qemu版本:qemu-8.2.0 在生产环境中,大多数的场景是 vmware 虚拟机迁移到 qemu 环境,一般是通过关机然后导出、导入磁盘镜像来实现。 如果要将 qemu 环境虚拟机迁移到 vmware 怎么办呢?要求…

Ruby on Rails Post项目设置网站初始界面

在构建了Ruby的Web服务器后,第三步就可以去掉框架的官方页面,设置自己的网页初始页了。 Linux系统安装Ruby语言-CSDN博客 、在Ubuntu中创建Ruby on Rails项目并搭建数据库-CSDN博客、 Ruby语言建立Web服务器-CSDN博客 了解Ruby onRails项目中的主要文件…

go语言对接S3存储的SDK(支持minio和OSS)

背景 在某个项目中,客户要求支持S3协议的存储,因为之前的项目是go来开发的支持的oss和minio 。 但并不一定支持S3的协议,而且使用了二种SDK,感觉比较麻烦。 既然客户提出来了要求。那我们改一下就是了。 操作 引入 go语言中有对…

《计算机英语》Unit1 计算机概述

期末试卷组成 1、选择20道 2、判断20道 3、词汇翻译(单词词组,参照课后习题) 4、翻译2道(一道原题,参照作业) Unit One Computer Overview 单元1 计算机概述 algorithm n. 算法 operate …

Python之scapy(1)基础使用

Python之scapy(1)基础使用 Author: Once Day Date: 2024年6月4日 一位热衷于Linux学习和开发的菜鸟,试图谱写一场冒险之旅,也许终点只是一场白日梦… 漫漫长路,有人对你微笑过嘛… 全系列文章可参考专栏: Python开发_Once-Day的博客-CSDN博…

CDGA认证一年考几次?重点考哪些内容?考试费用贵吗?

CDGA认证一年考四次。具体的考试日期通常安排在3月、6月、9月和12月的周末,但具体日期可通过联系DAMA中国或授权培训机构进行确认。 CDGA重点考试内容 关于考试的重点内容,CDGA认证主要考察考生对数据治理的相关知识和技能,考试内容主要涉及…

医学图像预处理之z分数归一化

在医学图像处理中,Z分数标准化(Z-score normalization)是一种常用的数据标准化方法,其目的是将数据集中的每个图像像素值转换为具有均值为0和标准差为1的标准化值。这种标准化方法有助于改善图像的质量,便于后续图像处…

【有趣分享】火柴人VS数学

今天看到一个很有趣的视频,是火柴人VS数学,大家感兴趣的可以看一下: 火柴人 VS 数学(Math)https://www.bilibili.com/festival/jzj2023?bvidBV1ph4y1g75E&spm_id_from333.337.search-card.all.click

易基因:MeRIP-seq等揭示RNA m6A去甲基化酶调控植物雄性不育的分子机制 | 科研速递

大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。 水稻是全球重要的农作物,也是单子叶植物模型。在水稻中,N6-甲基腺苷(m6A)mRNA修饰对植物的发育和胁迫响应至关重要。OsFIP37作为m6A甲基化…

Hive笔记-2

第 3 章 DDL (Data Definition Language) 数据定义 DDL数据定义语言 DML数据操作语言 3.1 数据库 (database) 3.1.1 创建数据库 1) 语法 CREATE DATABASE [IF NOT EXISTS] database_name [COMMENT database_comment] [LOCATION hdfs_path] [WITH DBPROPERTIES (property_…

【数学建模】——【新手小白到国奖选手】——【学习路线】

专栏:数学建模学习笔记 目录 ​编辑 第一阶段:基础知识和工具 1.Python基础 1.学习内容 1.基本语法 2.函数和模块 3.面向对象编程 4.文件操作 2.推荐资源 书籍: 在线课程: 在线教程: 2.数学基础 1.学习内…

Transformer学习理解

1.前言 本文介绍当下人工智能领域的基石与核心结构模型——Transformer,为什么说它是基石,因为以ChatGPT为代表的聊 天机器人以及各种有望通向AGI(通用人工智能)的道路上均在采用的Transformer。 Transformer也是当下NLP任…

API接口测试要注意什么?API接口如何开发?

API接口怎么保证数据安全?如何安全调用邮件API接口? API接口不仅能够确保系统的稳定性和可靠性,还能提高开发效率和用户满意度。然而,要进行有效的API接口测试,需要注意多个方面。AokSend将介绍一些关键点&#xff0c…

【云原生】Kubernetes----Metrics-Server组件与HPA资源

目录 引言 一、概述 (一)Metrics-Server简介 (二)Metrics-Server的工作原理 (三)HPA与Metrics-Server的作用 (四)HPA与Metrics-Server的关系 (五)HPA与…

百万级 QPS 接入层网关架构方案演进

文章目录 前言1、单机架构2、DNS 轮询3、Nginx 单机4、Nginx 主备 Keepalived5、LVS 主备 Keepalived Nginx 集群6、LVS 主备 Keepalived Nginx 集群 DNS 轮询 前言 随着PC、移动互联网的快速发展,越来越多的人通过手机、电脑、平板等设备访问各种各样APP、网…

pdf只要前几页,pdf怎么只要前几页

在现代办公和学习环境中,PDF文件已成为我们日常处理信息的重要工具。然而,有时我们并不需要整个PDF文件的内容,而只是其中的几页。那么,如何高效地提取PDF文件中的特定页面呢?本文将为您介绍几种实用的方法。 打开 “ …

阿里CEO个人投资的智驾公司,走了不一样的路

佑驾创新在去年8月和11月完成两轮融资,在今年5月底递表港交所,目前拿到了29家车企88款车型的量产订单。自动驾驶赛道不缺明星,这些因素本不足以凸显它的差异化。但是在招股书中,一条特殊的发展路线,却让佑驾创新显得不…

搭建开发模式下的以太坊私有链【Geth:1.14.5】

一、为什么用到私有链? 在以太坊的公有链上部署智能合约、发起交易需要花费以太币。而通过修改配置,可以在本机搭建一套以太坊私有链,因为与公有链没关系,既不用同步公有链庞大的数据,也不用花钱购买以太币&#xff0…