nodejs入门教程五:连接数据库的方法分析

发布时间 - 2026-01-11 00:48:21    点击率:

本文实例讲述了nodejs入门教程之连接数据库的方法。分享给大家供大家参考,具体如下:

参考文章链接:  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属性。

希望本文所述对大家nodejs程序设计有所帮助。


# nodejs  # 连接  # 数据库  # nodejs入门教程四:URL相关模块用法分析  # nodejs入门教程三:调用内部和外部方法示例  # nodejs入门教程二:创建一个简单应用示例  # nodejs入门教程一:概念与用法简介  # NodeJS测试框架mocha入门教程  # Nodejs极简入门教程(三):进程  # Nodejs极简入门教程(二):定时器  # Nodejs极简入门教程(一):模块机制  # nodejs教程 安装express及配置app.js文件的详细步骤  # NodeJS框架Express的模板视图机制分析  # Nodejs的express使用教程  # nodejs入门教程六:express模块用法示例  # 回调  # 连接数据库  # 会在  # 可选  # 连接池  # 将该  # 创建一个  # 放回  # 就会  # 也不  # 多个  # 给大家  # 自定义  # 只需要  # 可以使用  # 写到  # 如图  # 准备工作  # 转换为  # 时应 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  非常酷的网站设计制作软件,酷培ai教育官方网站?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  公司门户网站制作流程,华为官网怎么做?  如何打造高效商业网站?建站目的决定转化率  在线制作视频网站免费,都有哪些好的动漫网站?  教学论文网站制作软件有哪些,写论文用什么软件 ?  如何在阿里云高效完成企业建站全流程?  Laravel怎么导出Excel文件_Laravel Excel插件使用教程  Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程  Laravel事件监听器怎么写_Laravel Event和Listener使用教程  如何彻底删除建站之星生成的Banner?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  Laravel PHP版本要求一览_Laravel各版本环境要求对照  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  使用C语言编写圣诞表白程序  Swift开发中switch语句值绑定模式  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  详解Android图表 MPAndroidChart折线图  怎么用AI帮你为初创公司进行市场定位分析?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  Bootstrap CSS布局之列表  如何正确选择百度移动适配建站域名?  深圳网站制作平台,深圳市做网站好的公司有哪些?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  如何在IIS中新建站点并解决端口绑定冲突?  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  制作企业网站建设方案,怎样建设一个公司网站?  如何用PHP快速搭建高效网站?分步指南  Laravel怎么自定义错误页面_Laravel修改404和500页面模板  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  JavaScript如何实现错误处理_try...catch如何捕获异常?  Laravel如何保护应用免受CSRF攻击?(原理和示例)  MySQL查询结果复制到新表的方法(更新、插入)  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  如何快速搭建高效服务器建站系统?  浅谈Javascript中的Label语句  HTML 中动态设置元素 name 属性的正确语法详解  EditPlus 正则表达式 实战(3)  进行网站优化必须要坚持的四大原则  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  ,南京靠谱的征婚网站?