NodeJS 后端开发 06 连接MySQL

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 好久没分享了,今天分享一个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 
目录
相关文章
|
4月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
192 13
|
4月前
|
SQL 关系型数据库 MySQL
MySQL数据库连接过多(Too many connections)错误处理策略
综上所述,“Too many connections”错误处理策略涉及从具体参数配置到代码层面再到系统与架构设计全方位考量与改进。每项措施都需根据具体环境进行定制化调整,并且在执行任何变更前建议先行测试评估可能带来影响。
1324 11
|
4月前
|
SQL 关系型数据库 MySQL
排除通过IP访问MySQL时出现的连接错误问题
以上步骤涵盖了大多数遇到远程连接 MySQL 数据库时出现故障情形下所需采取措施,在执行每个步骤后都应该重新尝试建立链接以验证是否已经解决问题,在多数情形下按照以上顺序执行将能够有效地排除并修复大多数基本链接相关故障。
397 3
|
4月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
506 11
|
5月前
|
存储 关系型数据库 MySQL
修复.net Framework4.x连接MYSQL时遇到utf8mb3字符集不支持错误方案。
通过上述步骤大多数情况下能够解决由于UTF-encoding相关错误所带来影响,在实施过程当中要注意备份重要信息以防止意外发生造成无法挽回损失,并且逐一排查确认具体原因以采取针对性措施解除障碍。
334 12
|
8月前
|
开发框架 Java 关系型数据库
在Linux系统中安装JDK、Tomcat、MySQL以及部署J2EE后端接口
校验时,浏览器输入:http://[your_server_IP]:8080/myapp。如果你看到你的应用的欢迎页面,恭喜你,一切都已就绪。
568 17
|
8月前
|
Java 关系型数据库 MySQL
在Linux操作系统上设置JDK、Tomcat、MySQL以及J2EE后端接口的部署步骤
让我们总结一下,给你的Linux操作系统装备上最强的军队,需要先后装备好JDK的弓箭,布置好Tomcat的阵地,再把MySQL的物资原料准备好,最后部署好J2EE攻城车,那就准备好进军吧,你的Linux军团,无人可挡!
184 18
|
8月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
513 11
|
4月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
186 3
|
4月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。

推荐镜像

更多