【Node系列】连接数据库

本文涉及的产品
云原生网关 MSE Higress,422元/月
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 在Node.js代码中使用mysql模块来连接MySQL数据库、插入、删除和更新数据

一、连接MySql

首先,您需要安装mysql模块。在命令行中,导航到您的项目目录并输入以下命令:

npm install mysql

然后,您可以在Node.js代码中使用mysql模块来连接MySQL数据库、插入、删除和更新数据。以下是一个简单的示例:

var mysql = require('mysql');

// 创建数据库连接对象
var con = mysql.createConnection({
   
  host: "localhost", // 数据库服务器地址
  user: "yourusername", // 数据库用户名
  password: "yourpassword", // 数据库密码
  database: "mydb" // 数据库名称
});

// 连接到数据库
con.connect(function(err) {
   
  if (err) throw err;
  console.log("Connected to the MySQL server!");

  // 插入数据
  var sql = "INSERT INTO users (name, email) VALUES ('John Doe', 'john@example.com')";
  con.query(sql, function (err, result) {
   
    if (err) throw err;
    console.log("1 record inserted");
  });

  // 删除数据
  var sql = "DELETE FROM users WHERE id = 1";
  con.query(sql, function (err, result) {
   
    if (err) throw err;
    console.log("1 record deleted");
  });

  // 更新数据
  var sql = "UPDATE users SET name = 'Jane Doe' WHERE id = 1";
  con.query(sql, function (err, result) {
   
    if (err) throw err;
    console.log("1 record updated");
  });
});

在这个例子中,我们首先创建了一个名为"con"的连接对象,并使用mysql.createConnection()方法指定了数据库服务器的地址、用户名、密码和数据库名称。然后,我们调用con.connect()方法来建立与MySQL服务器的连接。如果连接成功,控制台将打印出"Connected to the MySQL server!"。然后,我们分别执行了插入、删除和更新数据的操作,并打印出相应的结果。如果发生错误,将抛出错误。

数据库连接参数
|参数 |描述|
|-------|-------|
host 主机地址 (默认:localhost)
user| 用户名
  password| 密码
  port 端口号 |(默认:3306)
  database |数据库名
  charset| 连接字符集(默认:'UTF8_GENERAL_CI',注意字符集的字母都要大写)
  localAddress| 此IP用于TCP连接(可选)
  socketPath| 连接到unix域路径,当使用 host 和 port 时会被忽略
  timezone |时区(默认:'local')
  connectTimeout| 连接超时(默认:不限制;单位:毫秒)
  stringifyObjects| 是否序列化对象
  typeCast |是否将列值转化为本地JavaScript类型值 (默认:true)
  queryFormat| 自定义query语句格式化方法
  supportBigNumbers| 数据库支持bigint或decimal类型列时,需要设此option为true (默认:false)
  bigNumberStrings |supportBigNumbers和bigNumberStrings启用 强制bigint或decimal列以JavaScript字符串类型返回(默认:false)
  dateStrings |强制timestamp,datetime,data类型以字符串类型返回,而不是JavaScript Date类型(默认:false)
  debug |开启调试(默认:false)
  multipleStatements| 是否许一个query中有多个MySQL语句 (默认:false)
  flags |用于修改连接标志
  ssl| 使用ssl参数(与crypto.createCredenitals参数格式一至)或一个包含ssl配置文件名称的字符串,目前只捆绑Amazon RDS的配置文件

二、连接MongoDB

首先,您需要安装mongodb模块。在命令行中,导航到您的项目目录并输入以下命令:

npm install mongodb

然后,您可以在Node.js代码中使用mongodb模块来连接MongoDB数据库、插入、删除和更新数据。以下是一个简单的示例:

var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017";

MongoClient.connect(url, function(err, db) {
   
  if (err) throw err;
  console.log("Connected to the MongoDB server!");

  // 插入数据
  var collection = db.collection('users');
  var user = {
    name: 'John Doe', email: 'john@example.com' };
  collection.insertOne(user, function(err, result) {
   
    if (err) throw err;
    console.log("1 record inserted");
  });

  // 删除数据
  var query = {
    name: 'John Doe' };
  collection.deleteOne(query, function(err, result) {
   
    if (err) throw err;
    console.log("1 record deleted");
  });

  // 更新数据
  var query = {
    name: 'Jane Doe' };
  var update = {
    $set: {
    name: 'Jane Doe' } };
  collection.updateOne(query, update, function(err, result) {
   
    if (err) throw err;
    console.log("1 record updated");
  });

  db.close();
});

在这个例子中,我们首先使用require('mongodb').MongoClient引入了MongoClient类,然后使用MongoClient.connect()方法连接到本地MongoDB服务器。如果连接成功,控制台将打印出"Connected to the MongoDB server!"。然后,我们分别执行了插入、删除和更新数据的操作,并打印出相应的结果。如果发生错误,将抛出错误。请注意,这个例子假设您已经有一个名为"users"的集合存在。您可以根据实际情况修改集合名称和查询条件。

三、相关链接

  1. node介绍
  2. npm详细安装教程
  3. 【Node系列】文件系统介绍及案例说明
  4. 【Node系列】创建第一个服务器应用
  5. 【Node系列】REPL详解
  6. 【Node系列】回调函数/事件循环
  7. 【Node系列】EventEmitter详解
  8. mysql模块文档
  9. MongoDB模块文档
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
2月前
|
数据库 C# 开发者
ADO.NET连接到南大通用GBase 8s数据库
ADO.NET连接到南大通用GBase 8s数据库
|
2月前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
2月前
|
JSON JavaScript 关系型数据库
node.js连接GBase 8a 数据库 并进行查询代码示例
node.js连接GBase 8a 数据库 并进行查询代码示例
|
2月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(上)
|
2月前
|
数据库连接 数据库 C#
Windows下C# 通过ADO.NET方式连接南大通用GBase 8s数据库(下)
本文接续前文,深入讲解了在Windows环境下使用C#和ADO.NET操作南大通用GBase 8s数据库的方法。通过Visual Studio 2022创建项目,添加GBase 8s的DLL引用,并提供了详细的C#代码示例,涵盖数据库连接、表的创建与修改、数据的增删查改等操作,旨在帮助开发者提高数据库管理效率。
|
2月前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
50 1
|
14天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
39 3
|
14天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
42 3
|
14天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
56 2
|
27天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
185 15