如何在Node.js中使用MySql进行数据增删改查

安装MySQL模块

javascript 复制代码
npm install mysql
// 或者
npm install mysql2

创建数据库连接

javascript 复制代码
// 引入mysql
const mysql = require("mysql");
// 连接池
const db = mysql.createPool({
  host:"localhost",
  user:"xxxx", // 我本地数据库的账户名
  password:"xxxxx", // 我本地的数据库登陆密码
  database:"xhhcoder", // 我自己创建的数据库名字
})

查询数据

javascript 复制代码
const sqlStr = 'select * from user';
db.query(sqlStr, (err, result)=>{
  if(err) return console.log('连接失败')
  select 查询语句,执行的结果是一个数组
  console.log('连接成功', result)
})


插入数据

javascript 复制代码
const user = {username: 'kobe', number: 24}
// 待执行的sql语句, ? 表示占位符
const sqlStr = 'insert into user (username, number) values (?, ?)';
// 使用数组的形式,依次为 ? 占位符指定具体的值
db.query(sqlStr, [user.username, user.number], (err, result) => {
  if(err) return console.log('数据插入失败')
  // 通过affectedRows属性来判断是否插入成功
  if(result.affectedRows == 1){
    console.log('数据插入成功')
  }
})


插入数据 - 快捷方式

javascript 复制代码
const user = {username: 'xhhCoder', number: 23}
// 待执行的sql语句, ? 表示占位符
const sqlStr = 'insert into user set ?';
// 使用数组的形式,依次为 ? 占位符指定具体的值
db.query(sqlStr, user, (err, result) => {
  if(err) return console.log('数据插入失败')
  // 通过affectedRows属性来判断是否插入成功
  if(result.affectedRows == 1){
    console.log('数据插入成功')
  }
})


修改数据

javascript 复制代码
const user = {username: 'xhhCoder', number: 6};
// 执行语句
const sqlStr = 'update user set number=? where username=?';
// []中的数据顺序,需要跟执行语句中 ? 的顺序保持一致
db.query(sqlStr, [user.number, user.username], (err, result)=>{
  if(err) return console.log('数据更新失败', err.message)
  // 通过affectedRows属性来判断是否更新成功
  if(result.affectedRows == 1){
    console.log('数据更新成功')
  }
})


修改数据 - 快捷方式

javascript 复制代码
const user = {username: 'lbj', number: 6};
// 执行语句
const sqlStr = 'update user set ? where username=?';
// []中的数据顺序,需要跟执行语句中 ? 的顺序保持一致
db.query(sqlStr, [user, user.username], (err, result)=>{
  if(err) return console.log('数据更新失败', err.message)
  // 通过affectedRows属性来判断是否更新成功
  if(result.affectedRows == 1){
    console.log('数据更新成功')
  }
})


删除数据

javascript 复制代码
const sqlStr = 'delete from user where username=?';
// 只有一个 ? 占位符的时候,可以不需要数组[]包括着参数
db.query(sqlStr, 'xhhCoder', (err, result)=>{
  if(err) return console.log('数据删除失败', err.message)
  // 通过affectedRows属性来判断是否更新成功
  if(result.affectedRows == 1){
    console.log('数据删除成功')
  }
})


相关推荐
爱上语文2 分钟前
Redis基础(4):Set类型和SortedSet类型
java·数据库·redis·后端
lifallen16 分钟前
Paimon vs. HBase:全链路开销对比
java·大数据·数据结构·数据库·算法·flink·hbase
Brookty1 小时前
【MySQL】JDBC编程
java·数据库·后端·学习·mysql·jdbc
_代号0071 小时前
MySQL梳理一:整体架构概览
后端·mysql
先做个垃圾出来………2 小时前
SQL的底层逻辑解析
数据库·sql
码不停蹄的玄黓2 小时前
深入拆解MySQL InnoDB可重复读(RR)隔离级别:MVCC+临键锁如何「锁」住一致性?
数据库·mysql·可重复读
paopaokaka_luck2 小时前
基于SpringBoot+Vue的酒类仓储管理系统
数据库·vue.js·spring boot·后端·小程序
用户91453633083913 小时前
MySQL查询执行顺序:一张图看懂SQL是如何工作的
mysql
Lx3523 小时前
MySQL物化视图:预计算查询结果的定期刷新
sql·mysql·性能优化
Lx3523 小时前
Mysql死锁日志分析:事务逻辑冲突的排查技巧
sql·mysql·性能优化