express.js 链接数据库

在Express.js中链接数据库通常取决于你选择的数据库类型。最常见的数据库类型包括关系型数据库(如MySQL, PostgreSQL)和非关系型数据库(如MongoDB)。下面我将分别介绍如何在Express.js项目中链接这两种类型的数据库。

1. 链接MySQL或PostgreSQL数据库

对于MySQL或PostgreSQL这样的关系型数据库,你可以使用mysqlpg(对于PostgreSQL)这样的npm包来链接数据库。这里以mysql为例:

首先,你需要安装mysql包:

bash 复制代码
npm install mysql

然后,在你的Express.js应用中,你可以这样设置数据库连接:

javascript 复制代码
const express = require('express');
const mysql = require('mysql');

const app = express();
const PORT = 3000;

// 数据库配置
const db = mysql.createConnection({
  host     : 'localhost',
  user     : 'yourUsername',
  password : 'yourPassword',
  database : 'yourDatabase'
});

// 连接到数据库
db.connect(err => {
  if (err) {
    return console.error('error: ' + err.message);
  }

  console.log('Connected to the MySQL server.');
});

// 示例路由
app.get('/', (req, res) => {
  db.query('SELECT * FROM yourTable', (err, results, fields) => {
    if (err) throw err;
    res.send(results);
  });
});

app.listen(PORT, () => {
  console.log(`Server running on port ${PORT}`);
});

// 优雅关闭数据库连接
process.on('SIGINT', () => {
  db.end(() => {
    console.log('MySQL connection is closed');
  });
});

2. 链接MongoDB数据库

对于MongoDB这样的非关系型数据库,你可以使用mongoose这样的npm包来链接数据库。mongoose提供了丰富的模型(Model)和文档(Document)操作功能。

首先,安装mongoose

bash 复制代码
npm install mongoose

然后,在你的Express.js应用中设置MongoDB连接:

javascript 复制代码
const express = require('express');
const mongoose = require('mongoose');

const app = express();
const PORT = 3000;

// MongoDB连接配置
mongoose.connect('mongodb://localhost:27017/yourDatabase', {
  useNewUrlParser: true,
  useUnifiedTopology: true
})
.then(() => console.log('MongoDB connected...'))
.catch(err => console.log(err));

// 示例模型
const yourSchema = new mongoose.Schema({
  name: String,
  age: Number
});

const YourModel = mongoose.model('YourModel', yourSchema);

// 示例路由
app.get('/', async (req, res) => {
  try {
    const items = await YourModel.find();
    res.send(items);
  } catch (err) {
    res.status(500).send(err);
  }
});

app.listen(PORT, () => {
  console.log(`Server running on port ${PORT}`);
});

注意:在上面的MongoDB示例中,我使用了async/await来处理异步操作,这是ES7引入的特性,它使得异步代码看起来和同步代码一样。确保你的Node.js版本支持async/await(Node.js 7.6+)。

以上就是在Express.js中链接MySQL/PostgreSQL和MongoDB数据库的基本方法。根据你的具体需求,你可能需要调整数据库连接配置或查询逻辑。

相关推荐
Mintopia5 分钟前
Three.js 力导向图:让数据跳起优雅的华尔兹
前端·javascript·three.js
晓得迷路了28 分钟前
栗子前端技术周刊第 84 期 - Vite v7.0 beta、Vitest 3.2、Astro 5.9...
前端·javascript·vite
独立开阀者_FwtCoder31 分钟前
最全301/302重定向指南:从SEO到实战,一篇就够了
前端·javascript·vue.js
Moment40 分钟前
给大家推荐一个超好用的 Marsview 低代码平台 🤩🤩🤩
前端·javascript·github
明似水1 小时前
用 Melos 解决 Flutter Monorepo 的依赖冲突:一个真实案例
前端·javascript·flutter
独立开阀者_FwtCoder1 小时前
stagewise:让AI与代码编辑器无缝连接
前端·javascript·github
20242817李臻1 小时前
20242817李臻-安全文件传输系统-项目验收
数据库·安全
江城开朗的豌豆2 小时前
JavaScript篇:对象派 vs 过程派:编程江湖的两种武功心法
前端·javascript·面试
行思理2 小时前
MongoDB慢查询临时开启方法讲解
数据库·mongodb
菥菥爱嘻嘻2 小时前
JS手写代码篇---手写ajax
开发语言·javascript·ajax