news 2026/6/15 14:29:35

【MySQL】node.js 如何判断连接池是否正确连接上了?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【MySQL】node.js 如何判断连接池是否正确连接上了?

在使用mysql2/promisecreatePool时,仅仅调用createPool是不会立即去连接数据库的。它是“懒加载”的,只有在执行第一次查询或者手动请求连接时,才会真正尝试建立连接。

要判断连接是否正确以及数据库是否存在,推荐以下两种方式:

方法一:手动获取并释放一个连接(推荐)

这是最标准的方法。通过调用pool.getConnection(),你可以触发一次真实的连接尝试。

importmysqlfrom'mysql2/promise';asyncfunctioncheckConnection(){letpool=mysql.createPool({host:configData.db_host,user:configData.db_user,database:configData.db_database,password:configData.db_password,waitForConnections:true,connectionLimit:10,queueLimit:0});try{// 尝试获取一个连接constconnection=awaitpool.getConnection();console.log('数据库连接成功!');// 释放连接回连接池connection.release();returnpool;}catch(err){// 判断错误类型if(err.code==='ER_BAD_DB_ERROR'){console.error('错误:数据库不存在!');}elseif(err.code==='ER_ACCESS_DENIED_ERROR'){console.error('错误:用户名或密码错误!');}elseif(err.code==='ECONNREFUSED'){console.error('错误:无法连接到数据库服务器(IP或端口错误)!');}else{console.error('连接失败,错误代码:'+err.code);console.error(err.message);}returnnull;}}constmyPool=awaitcheckConnection();

方法二:执行一个简单的测试查询

如果你不想手动获取连接,可以直接执行一个极简查询(如SELECT 1)。

try{// 这种方式也会触发一次连接请求awaitpool.query('SELECT 1');console.log('数据库连接验证通过');}catch(err){if(err.code==='ER_BAD_DB_ERROR'){console.error('数据库不存在');}else{console.error('连接失败:',err.message);}}

如何识别“数据库不存在”?

catch块中,你可以通过检查err.code属性来识别具体的错误:

  • ER_BAD_DB_ERROR(错误代码: 1049): 表示你指定的database在服务器上不存在。
  • ER_ACCESS_DENIED_ERROR(错误代码: 1045): 表示用户名或密码不对。
  • ENOTFOUND/EAI_AGAIN: 表示host地址解析失败。
  • ECONNREFUSED: 表示数据库服务没启动,或者端口号填错了。

进阶:如果数据库不存在,自动创建它

有时你希望程序启动时如果发现数据库不存在,就自动创建一个。这时候你创建 Pool 时不能指定 database,连接成功后再创建:

// 1. 先不指定数据库连接到服务器constpoolWithoutDB=mysql.createPool({host:configData.db_host,user:configData.db_user,password:configData.db_password});// 2. 执行创建命令awaitpoolWithoutDB.query(`CREATE DATABASE IF NOT EXISTS \`${configData.db_database}\``);// 3. 此时再关闭这个 pool,或者直接切换到目标数据库使用awaitpoolWithoutDB.end();// 4. 然后创建正式带数据库名的 poolconstpool=mysql.createPool({...configData});

总结

要判断连接情况,请在初始化后立刻执行一次await pool.getConnection(),并捕获err.code === 'ER_BAD_DB_ERROR'来识别数据库不存在的情况。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:54:10

Llama Factory实战:如何微调一个聊天机器人

Llama Factory实战:如何微调一个聊天机器人 如果你是一名开发者,想为自己的应用添加智能对话功能,但又缺乏相关经验,这篇文章就是为你准备的。我将带你使用Llama Factory这个强大的工具,快速上手微调一个聊天机器人&am…

作者头像 李华
网站建设 2026/6/15 12:53:23

云端炼丹新姿势:Llama Factory+预置镜像的完美组合

云端炼丹新姿势:Llama Factory预置镜像的完美组合 作为一名AI研究员,你是否经常被这样的问题困扰:每次测试不同参数对模型效果的影响时,都要重新配置环境,浪费大量时间?今天我要分享的Llama Factory预置镜…

作者头像 李华
网站建设 2026/6/15 13:03:21

开发效率革命:用AI快速掌握数据库差异

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 请创建一个交互式学习模块,帮助开发者在30分钟内掌握PostgreSQL和MySQL的核心区别。要求包含:1) 关键差异速查表 2) 语法差异对照练习 3) 常见报错解决方案…

作者头像 李华
网站建设 2026/6/12 23:58:28

快速验证:使用Windows Server 2019构建测试环境的5种方法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个快速环境搭建工具,支持:1)自动下载Windows Server 2019评估版;2)生成Hyper-V/VirtualBox/VMware虚拟机配置;3)创建Docker基…

作者头像 李华
网站建设 2026/6/15 12:53:02

ZETORA:AI如何革新你的编程工作流

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个基于ZETORA的AI辅助开发工具,能够根据自然语言描述自动生成代码片段,支持多种编程语言,包括Python、JavaScript和Java。工具应具备代码…

作者头像 李华
网站建设 2026/6/6 6:14:21

中文OCR识别秘籍:如何用CRNN提升90%准确率

中文OCR识别秘籍:如何用CRNN提升90%准确率 📖 技术背景:OCR文字识别的挑战与突破 光学字符识别(OCR)作为连接图像与文本的关键技术,广泛应用于文档数字化、票据识别、车牌读取、手写体转录等场景。然而&a…

作者头像 李华