express操作mysql数据库的方法总结

作为前端,我们无需去考虑数据库的问题,业务场景需要的话,我们可以mock数据,满足暂时的联调场景。但是对于数据库,我们前端可以不用,却不能不了解不懂。所以这篇文章整理下,nodejs框架express中怎么使用mysql这样的数据库。提升我们处理业务能力的水平!!!

安装mysql

1.硬安装,就是到mysql官网下载.exe安装包(window系统),mac自行百度哈
2.项目里面安装

npm i mysql
"dependencies": {"body-parser": "^1.20.2","cors": "^2.8.5","ejs": "^3.1.9","express": "^4.19.2","mysql": "^2.18.1"}

在这里插入图片描述

封装

const mysql = require("mysql");const db = mysql.createPool({host: "127.0.0.1",user: "root",password: "",database: "expressapp",
});module.exports = db;

database:数据库的名称,我们新建的表都放在这个库里,其他的字段见名知意

建库

这里大家可以选择图形化界面,也可以用cmd命令行,看个人习惯

我这里用的ideal自带的数据库可视化界面,大家可以自由发挥
在这里插入图片描述
在这里插入图片描述

联调开发

常见业务就是增删改查,所以我们分别来看看怎么在express里面操作

const db = require("../db/index");
//插入数据1const user = { username: "spider-man", password: "456789" };const sqlStr2 = "insert into tb_users (username,password) values (?,?)";db.query(sqlStr2, [user.username, user.password], (err, data) => {if (err) return console.log(err.message);if (data.affectedRows === 1) {console.log("插入成功");}
});//插入数据2  快速插入const user = { username: "hot-man", password: "987123" };const sqlStr2 = "insert into tb_users set ?";db.query(sqlStr2, user, (err, data) => {if (err) return console.log(err.message);if (data.affectedRows === 1) {console.log("插入成功");}
});

//删除数据,会真正删除数据,硬删除const sqlStr4 = "delete from tb_users where id = ?";db.query(sqlStr4, 7, (err, data) => {if (err) return console.log(err.message);if (data.affectedRows === 1) {console.log("删除成功");}});//标记删除,只是模拟删除,数据还在数据库,软删除
const sqlStr5 = "update tb_users set status = ? where id = ?";
db.query(sqlStr5, [1, 9], (err, data) => {if (err) return console.log(err.message);if (data.affectedRows === 1) {console.log("删除成功");}
});

//更新数据1const user = { id: 7, username: "aaa", password: "654321" };const sqlStr3 = "update tb_users set username = ? ,password = ? where id = ?";db.query(sqlStr3, [user.username, user.password, user.id], (err, data) => {if (err) return console.log(err.message);//执行update语句也是返回一个对象if (data.affectedRows === 1) {console.log("修改成功");}});//更新数据2--快捷方式const user = { id: 7, username: "sam1", password: "123456" };const sqlStr3 = "update tb_users set ? where id = ?";db.query(sqlStr3, [user, user.id], (err, data) => {if (err) return console.log(err.message);//执行update语句也是返回一个对象if (data.affectedRows === 1) {console.log("修改成功");}});

//查询数据const sqlStr = "select * from tb_users";db.query(sqlStr, (err, data) => {if (err) return console.log(err.message);console.log("🚀 ~ db.query ~ data:", data);});

一顿猛操作之后的数据库结果:

在这里插入图片描述

最后总结

列出下mysql数据库操作常见的命令行方式

show databases ;use expressapp;show tables ;//选择所有数据
select  * from tb_users;//选择特定字段的数据
select  id,username,status from  tb_users;//插入新数据
insert into tb_users  (username, password) values ('zs','11111'),('lusi','456123');
;//更新字段
update  tb_users set password='6565665',status = 1  where  id =  5;//删除记录
delete  from tb_users where  id = 4 or 5;select  * from tb_users where  id > 7;select  * from tb_users where  username != 'jack';select *
from tb_users where  id  = 7 or id =8;select  * from tb_users  order by  status desc, username asc;select  count(*) from tb_users where  status = 0;select count(*) as total  from tb_users;select username as user1,password  from tb_users;

这样,我们就在express这样的服务端框架里,实现了真实数据的处理,离大前端又近了一步!!_

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

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

相关文章

007 spring aop(通知)(xml)

文章目录 pom.xmlLogAspect.javaStudentServiceImpl.javaStudentService.javaapplicationContext.xmlStudentServiceImplTest.java pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"…

IDEA+Docker远程一键部署SpringBoot项目

一.引语 本文将学习使用IDEADocker远程一键部署SpringBoot项目&#xff0c;对比上传jar包到服务器&#xff0c;再通过java指令运行项目&#xff0c;极大程度的提高了项目部署效率。可谓不用不知道&#xff0c;一用再也停不下来~ 为了后续学习方便&#xff0c;需要提前进行如下…

Firebase集成

目标&#xff1a; 1&#xff09;集成Firebase; 2) 集成Firebase Crashlytics&#xff0c;监控APP崩溃 海外APP开发需要科学上网。 一、Firebase是什么&#xff1f; Firebase 是一个应用开发平台&#xff0c;可帮助您构建和拓展用户喜爱的应用和游戏。提供了应用的构建、发布…

Nuxt3 实战 (三):使用 release-it 自动管理版本号和生成 CHANGELOG

release-it 能做什么&#xff1f; 增加版本号并提交 Git生成变更日志&#xff08;Changelog&#xff09;并提交到 Git创建 Git 标签并推送到远程仓库发布到 npm 等软件仓库在 GitHub、GitLab 等平台创建发行版 前置知识 在看这篇文章之前&#xff0c;我们有必要了解一下 Sem…

css不知道宽度,如何绘制一个正方形

我们可以给当前盒子加一个伪元素&#xff0c;设置padding-bottom: 100%&#xff0c;就可以绘制一个正方形 <div class"parent"><div></div><div></div><div></div> </div> .parent{width:100%;padding:20px;displ…

Few-Shot目标检测数据集 | Few-Shot目标检测数据集_已经整理成MS-COCO数据格式_含60000+张图_可直接用于目标检测算法训练

项目应用场景 面向 Few-Shot 目标检测场景&#xff0c;项目提供 6000 张图&#xff0c;已经整理成 MS-COCO 数据格式&#xff0c;可用于 Few-Shot 目标检测的训练数据集&#xff0c;或作为 Few-Shot 目标检测数据集的补充。 数据集展示 数据集下载 > 具体参见项目 README.m…

人工智能_大模型023_AssistantsAPI_01_OpenAI助手的创建_API的调用_生命周期管理_对话服务创建---人工智能工作笔记0159

先来说一下一些问题: 尽量不要微调,很麻烦,而且效果需要自己不断的去测试. 如果文档中有图表,大量的图片去分析就不合适了. 是否用RAG搜索,这个可以这样来弄,首先去es库去搜能直接找到答案可以就不用去RAG检索了,也可以设置一个分,如果低于60分,那么就可以去进行RAG检索 微…

Teachable Machine模型之TensorFlow使用篇

前言: 使用在teachable machine训练的h5格式模型 tensorflow使用篇 1. 使用teachable machine训练模型 地址: 传送门, 需要梯子翻一下 训练后, 导出的时候可以选择三种类型 导出模型文件 converted_keras.zip (py版) 解压后得到 2. py项目中使用模型 根据你当时使用tea…

7.网络编程-安全

目录 引言 Session Cookie JWT (JSON Web Token) 网络攻击 CSRF DDoS 其他常见网络攻击类型及应对措施 引言 Session、Cookie 和 JWT 都是Web开发中用于实现用户状态管理和身份验证的技术。它们各自有不同的特点和应用场景&#xff1a; Session Session 是一种服务器…

基于erp业务的责任链模式实战

Handler接口是用来规范所有的责任链节点都要实现 处理数据的方法 AbstractSchHandlerContains 是责任链节点保存的抽象类 ScheduleHandlerContains 子类可以覆盖责任链节点保存容器实现自定义遍历责任链节点容器方法设置自定义容器 一. 创建责任链节点接口 用于规范责任链的处理…

volta(轻松切换管理Node.js版本)

Node.js版本管理 Volta提供了一个简单直观的命令行界面&#xff0c;可以轻松地安装、卸载、更新和切换Node.js版本。 Volta 既可以全局使用&#xff0c;也可以在项目级别使用&#xff0c;可以为每个项目单独设置node版本&#xff0c;nvm不行。 下载安装Volta 参考&#xff1a; …

蓝桥杯-网络安全比赛(5)基础学习-JavaScript原型链的prototype、constructor、object.create()、__proto__

JavaScript的prototype、constructor、Object.create()和__proto__通常不直接作为解题的关键&#xff0c;但它们对于理解和分析Web应用的安全性至关重要。 网络安全比赛通常涉及Web应用的漏洞挖掘和攻击&#xff0c;这要求参赛者具备深厚的Web开发知识&#xff0c;包括JavaScri…

深度学习的层、算子和函数空间

目录 一、层、算子和函数空间概念 二、层&#xff08;Layers&#xff09; 三、算子&#xff08;Operators&#xff09; 3.1常见算子 3.2常见算子的性质 四、函数空间&#xff08;Function Space&#xff09; 一、层、算子和函数空间概念 层&#xff08;Layers&#xff09…

自建远程桌面服务器,控制免root安卓手机和pc

RustDesk是一个开源的远程桌面软件&#xff0c;它允许用户通过互联网在不同设备之间共享桌面和控制权限。这款软件以最少的配置提供了自托管和安全保障&#xff0c;是一个类似于TeamViewer的开源替代品​ (RustDesk)​。RustDesk支持在Windows、macOS、Linux、iOS、Android以及…

[数据概念]对原始公开数据赋权的思考

“ 对于原始、公开信息&#xff0c;要充分保障整个社会对该类信息资源的合理利用&#xff0c;以维护信息公平和促进更大范围的创新。。” 2022年12月&#xff0c;党中央、国务院发布《关于构建数据基础制度更好发挥数据要素作用的意见》&#xff08;以下称《数据二十条》&#…

Java8新特性--lambda表达式

lambda表达式本质上是一个匿名函数&#xff0c;在lambda表达式中我们只需要关心参数列表以及方法体。优点是可以减少代码量。 1.语法 基本语法&#xff1a;(参数)->表达式 或 (参数) -> {语句;} 2.函数式接口 要了解lambda表达式&#xff0c;首先要了解什么是函数式接口…

互联网大厂ssp面经之路:计算机网络part2

什么是 HTTP 和 HTTPS&#xff1f;它们之间有什么区别&#xff1f; a. HTTP&#xff08;超文本传输协议&#xff09;和HTTPS&#xff08;安全超文本传输协议&#xff09;是用于在Web上传输数据的协议。它们之间的区别在于安全性和数据传输方式。 b. HTTP是一种不安全的协议&…

[RK3588-Android12] 关于HDMIN-IN视频调试命令

问题描述 如题关于HDMIN-IN视频应该如何调试。 解决方案&#xff1a; 视频调试 HDMI-IN 设备在内核中会被注册为 video 设备&#xff0c;生成的节点如&#xff1a;/dev/video8。 可以通过 v4l2-ctl 命令来获取设备信息和抓帧。 1.获取设备信息&#xff1a; v4l2-ctl -d /dev…

变分自编码器生成新的手写数字图像

变分自编码器&#xff08;Variational Autoencoder&#xff0c;VAE&#xff09;是一种生成模型&#xff0c;通常用于学习数据的潜在表示&#xff0c;并用于生成新的数据样本。它由两部分组成&#xff1a;编码器和解码器。 编码器&#xff08;Encoder&#xff09;&#xff1a;接…

用Echarts词云数据可视化热词表白​​

目录 1、使用前准备 2、准备工作 3、盒子搭建 4、整体展现 1、使用前准备 找到表白对象&#xff08;重中之重&#xff01;&#xff09;&#xff0c;不要一见钟情&#xff08;个人觉得&#xff1a;一见钟情属于见色起意&#xff01;&#xff09;&#xff0c;因为数据可视化需…