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();
相关推荐
Le_ee13 分钟前
sqli-labs靶场第七关——文件导出注入
数据库·sql·网络安全·php·sql注入·sqli—labs
dddaidai12327 分钟前
分布式ID和分布式锁
redis·分布式·mysql·zookeeper·etcd
不知几秋38 分钟前
Maven
java·数据库·maven
政沅同学44 分钟前
数据库实验报告 SQL SERVER 2008的基本操作 1
数据库
lyw20561944 分钟前
MySQL八股(自用)
数据库·mysql
MMMMMMMMMMemory2 小时前
pgsql14自动创建表分区
数据库·pgsql
文牧之2 小时前
PostgreSQL 配置设置函数
运维·数据库·postgresql
jllllyuz3 小时前
matlab实现蚁群算法解决公交车路径规划问题
服务器·前端·数据库
下雨天u4 小时前
maven dependencyManagement标签作用
java·数据库·maven
代码配咖啡4 小时前
国产数据库工具突围:SQLynx如何解决Navicat的三大痛点?深度体验报告
数据库