nodejs(五) 连接数据库

本文介绍了如何使用Node.js连接数据库,包括准备步骤、直接连接、利用连接池以及end()、destroy()和release()的区别。重点讲解了在操作完成后如何管理和关闭数据库连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考链接:  nodejs连接mysql

1.准备工作

在nodejs中没有mysql模块,但npm中提供了mysql,所以可以使用npm安装mysql
命令:npm install mysql, 会生成 node_modules 文件夹 , 如图

执行后发现报了一个警告,说没有package.json 这个文件,只需要执行 npm init -f 的命令就会生成一个这个文件

2.直接连接数据库

mysql.createConnection(Object) 方法与 mysql.createPool(Object)的参数
	host:       连接数据库所在的主机名. (默认: localhost)
    port:       连接端口. (默认: 3306)
    localAddress:   用于TCP连接的IP地址. (可选)
    socketPath:     链接到unix域的路径。在使用host和port时该参数会被忽略.
    user:         MySQL用户的用户名.
    password:       MySQL用户的密码.
    database:       链接到的数据库名称 (可选).
    charset:       连接的字符集. (默认: 'UTF8_GENERAL_CI'.设置该值要使用大写!)
    timezone:       储存本地时间的时区. (默认: 'local')
    stringifyObjects:   是否序列化对象. See issue #501. (默认: 'false')
    insecureAuth:     是否允许旧的身份验证方法连接到数据库实例. (默认: false)
    typeCast:       确定是否讲column值转换为本地JavaScript类型列值. (默认: true)
    queryFormat:     自定义的查询语句格式化函数.
    supportBigNumbers: 数据库处理大数字(长整型和含小数),时应该启用 (默认: false).
    bigNumberStrings: 启用 supportBigNumbers和bigNumberStrings 并强制这些数字以字符串的方式返回(默认: false). 
    dateStrings: 强制日期类型(TIMESTAMP, DATETIME, DATE)以字符串返回,而不是一javascript Date对象返回. (默认: false)
    debug: 是否开启调试. (默认: false)
    multipleStatements: 是否允许在一个query中传递多个查询语句. (Default: false)
    flags: 链接标志.

连接数据库
var mysql  = require('mysql');  //调用MySQL模块
//创建一个connection
var connection = mysql.createConnection({
    host: '192.168.3.3',       //主机
    user: 'root',               //MySQL认证用户名
    password: 'x5',        //MySQL认证用户密码
    database: 'dason_yu',
    port: '3306'                   //端口号
});
//创建一个connection
connection.connect(function(err){
    if(err){
        console.log('[query] - :'+err);
        return;
    }
    console.log('[connection connect]  succeed!');
});
//执行sql语句
var userAddSql = 'insert into user (id,name,money) values(?,?,?)';
var param = [3,'ccc',200];
/**
 * 执行所有类型的 sql 语句
 * query(sql,arr[],function)
 * @parms: sql:sql语句  arr: 填充站位符的数组,可以缺省
 *          function: 回调函数,result: 结果集,对象组成的数组
 */
connection.query(userAddSql,param,function(err,rs){
    if(err){
        console.log('insert err:',err.message);
        return;
    }
    console.log('insert success');
});
//关闭connection
connection.end(function(err){
    if(err){
        console.log(err.toString());
        return;
    }
    console.log('[connection end] succeed!');
});


3.使用连接池连接数据库

将下面代码写到 httpServer.js 文件中
使用在命令行窗口中 node httpServer.js 运行
var mysql = require('mysql'); //用于创建数据库连接

var pool = mysql.createPool({// 创建数据库连接池
    host : '127.0.0.1' ,
    user : 'root' ,
    password : 'root' ,
    database : 'dason',
    multipleStatements: true

});
/**
 * 获取数据库连接
 * @parms: err:异常 connnection:数据库连接对象
 *
 */

pool.getConnection(function(err,connection){
    if(err){
        console.log(err);
    }
    /**
     * 执行所有类型的 sql 语句
     * query(sql,arr[],function)
     * @parms: sql:sql语句  arr: 填充站位符的数组,可以缺省
     *          function: 回调函数,result: 结果集,对象组成的数组
     */
    connection.query('SELECT * FROM user',function(err,result){
        console.log(result);
        connection.release();//将连接放回连接池
    });
});

结果:
[ RowDataPacket { id: 1, name: 'a', email: 'a@123' },
  RowDataPacket { id: 2, name: 'b', email: 'b@123' },
  RowDataPacket { id: 4, name: 'd', email: 'd@123' },
  RowDataPacket { id: 5, name: 'e', email: 'e@123' },
  RowDataPacket { id: 6, name: 'f', email: 'f@123' },
  RowDataPacket { id: 3, name: 'c', email: 'c@123' },
  RowDataPacket { id: 7, name: 'g', email: 'g@123' } ]

4. end() 与 destroy()、release()

end() 接受一个回调函数,并且会在query结束之后才触发,如果query出错,仍然会终止链接,错误会传递到回调函数中处理。

destroy() 立即终止数据库连接,即使还有query没有完成,之后的回调函数也不会在触发。

release() 将连接放回连接池中。 

5.package.json

npm install express –save

npm install express –save-dev

上面代码表示单独安装express模块,

–save参数表示将该模块写入dependencies属性,

–save-dev表示将该模块写入devDependencies属性。


### Node.js 连接数据库的示例代码 以下是基于不同类型的 SQL 数据库(MySQL、PostgreSQL 和 SQLite)提供的 Node.js 示例代码。 #### MySQL 数据库连接示例 为了连接到 MySQL 数据库,可以使用 `mysql2` 模块。此模块提供高性能和良好的兼容性[^3]。 ```javascript // 安装 mysql2 模块:npm install mysql2 const mysql = require('mysql2'); // 创建数据库连接池 const pool = mysql.createPool({ host: 'localhost', // 数据库主机地址 user: 'root', // 用户名 password: 'password', // 密码 database: 'testdb' // 使用的数据库名称 }); // 执行查询语句 pool.query('SELECT * FROM users WHERE id = ?', [1], (error, results) => { if (error) throw error; console.log(results); }); ``` --- #### PostgreSQL 数据库连接示例 对于 PostgreSQL 数据库,可使用 `pg` 模块实现连接功能[^1]。 ```javascript // 安装 pg 模块:npm install pg const { Client } = require('pg'); // 初始化客户端配置 const client = new Client({ host: 'localhost', port: 5432, user: 'postgres', password: 'your_password', database: 'your_database' }); // 建立连接并执行查询 client.connect() .then(() => client.query('SELECT * FROM users')) .then(res => { console.log(res.rows); return client.end(); }) .catch(err => console.error(err)); ``` --- #### SQLite 数据库连接示例 SQLite 是一种轻量级嵌入式关系型数据库管理系统。下面是一个通过 `sqlite3` 模块访问 SQLite 数据库的例子[^2]。 ```javascript // 安装 sqlite3 模块:npm install sqlite3 const sqlite3 = require('sqlite3').verbose(); // 打开或创建一个新的 SQLite 数据库文件 const db = new sqlite3.Database('./mydatabase.db'); // 查询指定条件的数据 db.get('SELECT name, email FROM users WHERE id = ?', [1], (err, row) => { if (err) { return console.error(err.message); } console.log(`Name: ${row.name}, Email: ${row.email}`); }); // 关闭数据库连接 db.close((err) => { if (err) { return console.error(err.message); } console.log('Closed the database connection.'); }); ``` 以上三种方式分别展示了如何利用不同的第三方模块完成与各类 SQL 数据库之间的交互操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值