当前位置: 首页 > article >正文

Nodejs+MySQL数据库管理

常用操作方式

  • 直接执行SQL语句
  • 使用占位符(防止SQL注入)[推荐]
  • 使用 async/await(结合 mysql2/promise
  • 使用 ORM(如 Sequelize

执行方式分类和比较

按数据库连接管理分类

  • 普通连接
  • 使用连接池(pool,推荐)
  • 使用事务(保证数据一致性)

普通连接

每次查询时创建和关闭连接

const db = mysql.createConnection({ /* 配置 */ });
db.connect();
db.query('INSERT INTO users SET ?', { name: 'Alice', email: 'alice@example.com' });
db.end();

缺点:大量查询时性能低

使用连接池(pool,推荐)

const pool = mysql.createPool({ connectionLimit: 10, /* 其他配置 */ });

pool.query('INSERT INTO users SET ?', { name: 'Alice', email: 'alice@example.com' }, (err, result) => {
  if (err) throw err;
  console.log('插入成功', result.insertId);
});

优点:适合高并发,多个查询共享连接池。

推荐用于生产环境

使用事务(保证数据一致性)

如果多个 SQL 语句必须要么全部成功,要么全部失败(如银行转账),可以使用事务

db.beginTransaction(err => {
  if (err) throw err;

  db.query('UPDATE accounts SET balance = balance - 100 WHERE id = 1', err => {
    if (err) return db.rollback(() => console.error(err));

    db.query('UPDATE accounts SET balance = balance + 100 WHERE id = 2', err => {
      if (err) return db.rollback(() => console.error(err));

      db.commit(err => {
        if (err) return db.rollback(() => console.error(err));
        console.log('✅ 事务提交成功');
      });
    });
  });
});

适用于银行、订单支付等场景

确保数据一致性,不会出现资金丢失问题

总结

  • 普通增删改查使用占位符 (**?**) 方式
  • 高并发使用 **pool** 连接池
  • 异步处理 ➝ **使用 ****mysql2/promise**
  • 订单/支付系统使用事务

http://www.kler.cn/a/585856.html

相关文章:

  • 手势调控屏幕亮度:Python + OpenCV + Mediapipe 打造智能交互体验
  • 3ds Max 导入到 After Effects 还原摄像机要注意事项--deepseek
  • 掌握市场先机:9款销售渠道管理工具深度测评
  • 蓝桥杯备考:01背包之优化问题。
  • Android应用出海之Klarna登录以及kakao登录
  • 【DeepSeek】一文详解GRPO算法——为什么能减少大模型训练资源?
  • axis=0 和 axis=1的区分设置matplotlib正常显示中文和负号
  • 在 Django 中通过 `/media/xxxx` URL 访问上传资源的安全性与实践
  • 神经网络中常用语言特性(python)(待完善)
  • GD32F4xx系列单片机-串口配合DMA的使用
  • 悬镜夫子ASPM数字供应链安全态势感知平台
  • JAVA中的多态性以及它在实际编程中的作用
  • 前端笔试高频算法题及JavaScript实现
  • iWebOffice2015 中间件如何在Chrome107及之后的高版本中加载
  • wepy微信小程序自定义底部弹出框功能,显示与隐藏效果(淡入淡出,滑入滑出)
  • Linux中grep、sed和awk常见用法总结
  • vscode怎么debug vue项目
  • 68.Harmonyos NEXT 图片预览组件应用实践(一):相册与社交场景
  • C++刷题(一):顺序表 + 单链表
  • OpenHarmony-XTS测试