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 分钟前
PostgreSQL 日常运维全指南:从基础操作到备份恢复
运维·数据库·postgresql
daad7771 小时前
wifi_note
运维·服务器·数据库
计算机毕设vx_bysj68692 小时前
【免费领源码】77196基于java的手机银行app管理系统的设计与实现 计算机毕业设计项目推荐上万套实战教程JAVA,node.js,C++、python、大屏数据可视化
java·mysql·智能手机·课程设计
吴声子夜歌2 小时前
ES6——正则的扩展详解
前端·mysql·es6
xixingzhe22 小时前
Mysql统计空间增量
数据库·mysql
程序员萌萌2 小时前
Java之mysql实战讲解(三):聚簇索引与非聚簇索引
java·mysql·聚簇索引
程序员萌萌3 小时前
Redis的缓存机制和淘汰策略详解
数据库·redis·缓存机制·淘汰策略
不剪发的Tony老师3 小时前
SQLite 3.53.0版本发布,重要更新
数据库·sqlite
Bczheng13 小时前
九.Berkeley DB数据库 序列化和钱包管理(1)
数据库
cozil3 小时前
记录mysql创建数据库未指定字符集引发的问题及解决方法
数据库·mysql