NodeJS 后端开发 06 连接MySQL

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS Agent(兼容OpenClaw),2核4GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 好久没分享了,今天分享一个NodeJS连接MySQL数据库的JS库:db.js

首先,启动MySQL服务器并准备数据库Profile

(下图为MacBook 单机版MySQL Server)

image.png

数据库Profile信息包含:目标数据库服务器IP,端口,用户账户和密码,还有目标数据库名称。

编写连接数据库的JS函数

将下面内容复制到db.js文件

const mysql =  require('mysql');
//创建一个数据库连接
const db =  mysql.createConnection({
    host: "localhost",
    port: 3306,
    user: "root",
    password: "12345678"
});
const logDbStat = function(){
    console.log("db state %s and threadID %s", db.state, db.threadId);
    // console.log("db detail:", db);
}
//在此时,仍旧未有实际连接到数据库
logDbStat();
console.log('start to connect mysql');
db.connect(function(err){
    if(err){
        console.log('fail to connect db',err.stack);
        throw err;
    }
    // 这里正真连接上数据库了。
    logDbStat();
});
const close = function(){
    db.destroy();
    console.log('db disconnected');
    logDbStat();
};
//定义一个计数器和runSql函数
//作用是跟踪输入的SQL与输出结果,也对数据库操作做一个简单包装。
var counter = 0;
const runSql = function(sql, callback){
    counter++;
    var cv = counter;
    console.log('run sql[%s] :[%s]',cv, sql);
    db.query(sql, function(error, result, fields){
        try{
            if(error) throw error;
            console.log('[%s] result:', cv, result); // use cv instead of counter, as counter is part of 'global', it will be polluted
        }finally{
            if(callback) callback(result, fields);
        }
    });
}
// 执行SQL语句
const myDb = 'demo20210330';
runSql("CREATE DATABASE IF NOT EXISTS " + myDb 
  + " DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci ; ");
runSql("USE " + myDb);
//创建公司数据表
runSql("CREATE TABLE IF NOT EXISTS COMPANY ( "
  + " ID int(11) NOT NULL AUTO_INCREMENT,    "
  + " NAME varchar(64) NOT NULL UNIQUE, "
  + " AGE int(8) NOT NULL, "
  + " ADDRESS text DEFAULT NULL, "
  + " STOCK_PRICE decimal(10,3) DEFAULT NULL, "
    + "  PRIMARY KEY (ID) "
    + " ) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8; ");
runSql("TRUNCATE TABLE COMPANY ;");
//插入三条公司股价信息
runSql(" INSERT INTO COMPANY "
  + "(NAME, AGE, ADDRESS, STOCK_PRICE ) VALUES "
    + "('Alibaba', 21, 'Hangzhou', 230.35), "
    + "('Tencent', 31, 'Shenzhen', 610.00), "
    + "('XiaoMi', 10, 'Beijing', 25.05) ; ");
// 查询所有公司股票信息和地址等
const querySql = "SELECT * FROM COMPANY ;";
runSql(querySql, function(result,fields){
    console.log('query result:', result);
});
/**
db.query(querySql, function(err, rows){
    if(err){
        console.log('error ' + err);
        throw err;
    }
    console.log('query output=');
    console.log(rows);
});
*/
// close(); // don't close here as the query function may not completed.
runSql("SELECT 1 ; ", function(result, fields){
    close();
});
// runSql(" DELETE FROM COMPANY ;");

或者从我的代码库下载:https://codechina.csdn.net/geeklevin/nodejs-api-006-db


重点函数解析

runSql(上面代码中对SQL语句执行的包装),使用了全局counter变量,并允许用户调用端提供一个回调函数。


比如代码最后执行‘SELECT 1; ', 执行回调关闭数据库连接。


数据库连接用完,必须进行管理,如果不适当关闭回导致数据库服务器端连接过多而拒绝新的数据库连接,影响其他实例,这里不做细讲。


执行node db.js 运行效果


image.png

image.png

第六条语句:查找到3条记录,并输出Alibaba,Tencent,XiaoMi 三个公司信息及股票价格等。

image.png

结果分析

从上面截图看,runSql函数顺序执行,可是SQL执行结果(result)对象是不同时输出(异步)的。


所以在设计runSql函数的时候,加入了counter计数器,这样可以根据输出,对应找到相应的下标(比如第六条SELECT SQL)结果。


本文的db.js不作为生产环境使用,仅供普通开发者参考,学习NodeJS连接数据库,具体的数据库SQL语句,读者可自行查找学习。



引用:


https://www.npmjs.com/package/mysql

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
698 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
10月前
|
人工智能 Java API
后端开发必看:零代码实现存量服务改造成MCP服务
本文介绍如何通过 **Nacos** 和 **Higress** 实现存量 Spring Boot 服务的零代码改造,使其支持 MCP 协议,供 AI Agent 调用。全程无需修改业务代码,仅通过配置完成服务注册、协议转换与工具映射,显著降低改造成本,提升服务的可集成性与智能化能力。
2798 1
|
10月前
|
前端开发 Java 数据库连接
后端开发中的错误处理实践:原则与实战
在后端开发中,错误处理是保障系统稳定性的关键。本文介绍了错误分类、响应设计、统一处理机制及日志追踪等实践方法,帮助开发者提升系统的可维护性与排障效率,做到防患于未然。
|
12月前
|
Java 关系型数据库 MySQL
在Linux平台上进行JDK、Tomcat、MySQL的安装并部署后端项目
现在,你可以通过访问http://Your_IP:Tomcat_Port/Your_Project访问你的项目了。如果一切顺利,你将看到那绚烂的胜利之光照耀在你的项目之上!
558 41
|
12月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
618 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
12月前
|
开发框架 Java 关系型数据库
在Linux系统中安装JDK、Tomcat、MySQL以及部署J2EE后端接口
校验时,浏览器输入:http://[your_server_IP]:8080/myapp。如果你看到你的应用的欢迎页面,恭喜你,一切都已就绪。
717 17
|
12月前
|
Java 关系型数据库 MySQL
在Linux操作系统上设置JDK、Tomcat、MySQL以及J2EE后端接口的部署步骤
让我们总结一下,给你的Linux操作系统装备上最强的军队,需要先后装备好JDK的弓箭,布置好Tomcat的阵地,再把MySQL的物资原料准备好,最后部署好J2EE攻城车,那就准备好进军吧,你的Linux军团,无人可挡!
404 18
|
12月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
627 11
|
前端开发 JavaScript 关系型数据库
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
883 5
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
|
12月前
|
开发框架 关系型数据库 Java
Linux操作系统中JDK、Tomcat、MySQL的完整安装流程以及J2EE后端接口的部署
然后Tomcat会自动将其解压成一个名为ROOT的文件夹。重启Tomcat,让新“植物”适应新环境。访问http://localhost:8080/yourproject看到你的项目页面,说明“植物”种植成功。
323 10

推荐镜像

更多