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

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

安装mysql

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

2.项目里面安装

bash 复制代码
npm i mysql
json 复制代码
"dependencies": {
    "body-parser": "^1.20.2",
    "cors": "^2.8.5",
    "ejs": "^3.1.9",
    "express": "^4.19.2",
    "mysql": "^2.18.1"
  }

封装

js 复制代码
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里面操作

js 复制代码
const db = require("../db/index");
//插入数据1
 const 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("插入成功");
   }
});

js 复制代码
//删除数据,会真正删除数据,硬删除
 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("删除成功");
  }
});

js 复制代码
//更新数据1

 const 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("修改成功");
   }
 });

js 复制代码
//查询数据
 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数据库操作常见的命令行方式

bash 复制代码
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这样的服务端框架里,实现了真实数据的处理,离大前端又近了一步!!_

相关推荐
Java水解31 分钟前
【MySQL】从零开始学习MySQL:基础与安装指南
后端·mysql
沢田纲吉5 小时前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql
Java水解1 天前
Mysql查看执行计划、explain关键字详解(超详细)
后端·mysql
知其然亦知其所以然1 天前
MySQL 社招必考题:如何优化查询过程中的数据访问?
后端·mysql·面试
DemonAvenger1 天前
NoSQL与MySQL混合架构设计:从入门到实战的最佳实践
数据库·mysql·性能优化
程序新视界1 天前
如何在MySQL中创建聚集索引?
mysql
AAA修煤气灶刘哥2 天前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
程序新视界2 天前
学习MySQL绕不开的两个基础概念:聚集索引与非聚集索引
mysql
RestCloud2 天前
跨境数据传输:ETL如何处理时区与日期格式差异
mysql·api
得物技术2 天前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql