Nodejs+MySQL数据库管理

常用操作方式

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

执行方式分类和比较

按数据库连接管理分类

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

普通连接

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

javascript 复制代码
const db = mysql.createConnection({ /* 配置 */ });
db.connect();
db.query('INSERT INTO users SET ?', { name: 'Alice', email: '[email protected]' });
db.end();

缺点:大量查询时性能低

使用连接池(pool,推荐)

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

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

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

推荐用于生产环境

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

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

javascript 复制代码
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**
  • 订单/支付系统使用事务
相关推荐
Elastic 中国社区官方博客30 分钟前
拆解 “ES 已死“ 伪命题:Agentic RAG 时代搜索引擎的终极形态
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
懒大王爱吃狼1 小时前
Python + Qt Designer构建多界面GUI应用程序:Python如何调用多个界面文件
开发语言·数据库·python·qt·mysql·python基础·命令模式
梦尘啊1 小时前
存储引擎详解:LSM-Tree与B+树比较
数据库·后端
jay丿1 小时前
Django 集成 Redis 数据库指南
数据库·redis·django
用户4099322502121 小时前
FastAPI性能优化指南:参数解析与惰性加载
前端·数据库·后端
计算机学姐1 小时前
基于Asp.net的高校迎新管理系统
vue.js·vscode·后端·mysql·sqlserver·c#·asp.net
多云的夏天1 小时前
Ubuntu 24.04-JAVA-JDBC-mysql
java·开发语言·mysql
boJIke3 小时前
分库分表与NewSQL数据库的区别及适用场景
数据库·new sql
Moshow郑锴4 小时前
基于SpringBoot3+Druid数据库连接池与外部PostgreSQL的Kubernetes Pod YAML全解析
数据库·容器·kubernetes
失业写写八股文4 小时前
数据库基础:InnoDB MVCC实现原理图
数据库