Node.js 连接 mysql 数据库

安装 mysql2 模块

bash 复制代码
npm install mysql2

使用 mysql2

连接池的方式,示例1

TypeScript 复制代码
import mysql from 'mysql2';

// 创建连接池
const pool = mysql.createPool({
    host: '127.0.0.1',
    port: 3306,
    user: 'root',
    password: '123456',
    database: 'test'
});

// 获取连接并执行 sql 语句,execute 方法不用手动调用释放连接,连接池会自动管理连接
pool.execute("update test set age = 22 where name = 'Tom'", (err, results, fields) => {
    if (err) {
        console.error(err);
        return;
    }
    console.log(results); // 打印查询结果
});

连接池的方式,示例2,手动释放连接

TypeScript 复制代码
import mysql from 'mysql2';

// 创建连接池
const pool = mysql.createPool({
    host: '127.0.0.01',
    port: 3306,
    user: 'root',
    password: '123456',
    database: 'test'
});

// 获取连接
pool.getConnection((err, connection) => {
    if (err) {
        console.error(err);
        return;
    }

    // 执行 sql 语句,防止 sql 注入的方式
    connection.execute('UPDATE test SET age = ? WHERE name = ?', [23, 'Tom'], (err, results, fields) => {
        if (err) {
            console.error(err);
        } else {
            console.log(results); // 打印查询结果
        }

        // 手动释放连接
        connection.release();
    });
});

非连接池的方式

TypeScript 复制代码
import mysql from 'mysql2';

// 创建一个连接
const connection = mysql.createConnection({
    host: '192.168.189.71',
    port: 3306,
    user: 'root',
    password: '123456',
    database: 'test'
});

// 执行查询,也可以使用 connection.execute
connection.query('SELECT * FROM test', (err, results, fields) => {
    if (err) {
        console.error(err);
        return;
    }
    console.log(results); // 打印查询结果
});

// 关闭连接
connection.end();

Promise 的方式

TypeScript 复制代码
import mysql from 'mysql2/promise';

// 创建连接池
const pool = mysql.createPool({
    host: '127.0.0.1',
    port: 3306,
    user: 'root',
    password: '123456',
    database: 'test'
});

async function getTest() {
    const [rows, fields] = await pool.execute('SELECT * FROM test');
    console.log(rows); // 打印查询结果
}

getTest();

事务

TypeScript 复制代码
import mysql from 'mysql2/promise';

// 创建连接池
const pool = mysql.createPool({
    host: '127.0.0.1',
    port: 3306,
    user: 'root',
    password: '123456',
    database: 'test'
});

// 使用事务执行多个查询
async function performTransaction() {
    const connection = await pool.getConnection();

    try {
        await connection.beginTransaction();

        // 执行多个查询
        await connection.execute('INSERT INTO test (id, name, age) VALUES (?, ?, ?)', [7, 'zs', '20']);
        await connection.execute('INSERT INTO test (id, name, age) VALUES (?, ?, ?)', [8, 'ls', '21']);

        // 提交事务
        await connection.commit();
        console.log('Transaction completed');
    } catch (err) {
        // 如果出错,回滚事务
        await connection.rollback();
        console.error('Transaction failed', err);
    } finally {
        // 释放连接
        connection.release();
    }
}

performTransaction();
相关推荐
Mr_li8 小时前
NestJS 集成 TypeORM 的最优解
node.js·nestjs
UIUV10 小时前
node:child_process spawn 模块学习笔记
javascript·后端·node.js
李广坤10 小时前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
前端付豪1 天前
Nest 项目小实践之注册登陆
前端·node.js·nestjs
Turnip12021 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区1 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
天蓝色的鱼鱼1 天前
Node.js 中间层退潮:从“前端救星”到“成本噩梦”
前端·架构·node.js
codingWhat2 天前
uniapp 多地区、多平台、多环境打包方案
前端·架构·node.js
小p2 天前
nodejs学习: 服务器资源CPU、内存、硬盘
node.js
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript