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();
相关推荐
小云数据库服务专线21 分钟前
GaussDB 数据库架构师修炼(十八) SQL引擎-分布式计划
数据库·数据库架构·gaussdb
秋已杰爱1 小时前
Redis分布式锁
数据库·redis·分布式
haogexiaole8 小时前
Redis优缺点
数据库·redis·缓存
在未来等你8 小时前
Redis面试精讲 Day 27:Redis 7.0/8.0新特性深度解析
数据库·redis·缓存·面试
胡gh9 小时前
你一般用哪些状态管理库?别担心,Zustand和Redux就能说个10分钟
前端·面试·node.js
新法国菜10 小时前
MySql知识梳理之DML语句
数据库·mysql
老华带你飞10 小时前
校园交友|基于SprinBoot+vue的校园交友网站(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·校园交友网站
许泽宇的技术分享10 小时前
Text2API与Text2SQL深度对比:自然语言驱动的数据交互革命
数据库·windows·microsoft
roamingcode10 小时前
Claude Code NPM 包发布命令
前端·npm·node.js·claude·自定义指令·claude code
gc_229910 小时前
运行npm run命令报错“error:0308010C:digital envelope routines::unsupported”
npm·node.js