Node.js版MVC之数据库篇

这是该系列的第二篇,上一篇已经选好了技术框架,就得开始操刀敲代码了,下面跟着作者的思路实现数据库的创建和加载

第一步:创建目录

模块主要沿用了后端的模块思想,主要分为 controllerdaoservicedata-sourcemodels,其中models模块用于表达数据表对象,data-source 模块用于表达数据库连接对象

第二步:读取配置文件

该脚手架采用了yaml语言的配置文件,只需将配置文件读取解析出来即可

配置文件如下:

yml 复制代码
base: service
datasource:
  - master:
      url: test.sqlite
      models: models

加载代码如下:

js 复制代码
const fse = require('fs-extra')
const path  = require('path')
const YAML = require('yaml')
/**
 * load the config file
 */
const appFile = fse.readFileSync(path.join(__dirname,'application.yml'), 'utf8')
const config = YAML.parse(appFile)

第三步:创建数据表对象

一个具有ORM特色的数据库框架,最主要的是对象-表的关系的建立,以下代码就是创建了一个 User模型,用于 User对象User表建立映射关系

js 复制代码
module.exports = (sequelize , DataTypes)=> {
  let User = sequelize.define('User',{
    firstName: {
      type: DataTypes.STRING,
      allowNull: false
    },
    lastName: {
      type: DataTypes.STRING
    }
  })
  return User
}

第四步:创建 DataSource

通过配置文件,自动构建DataSource,同时支持多数据源的构建,代码如下:

js 复制代码
const fse = require('fs-extra')
const {Sequelize , DataTypes} = require('sequelize')
const path = require('path')

module.exports =  dataSources => {
  let map = new Map()
  dataSources.forEach( async dataSource => {
    let [name, config] =  Object.entries(dataSource)[0]
    let sequelize = null
    if(!config.dialect || config.dialect === 'sqlite'){
      sequelize = new Sequelize({
        storage: config.url,
        dialect: 'sqlite'
      })
    } else {
    sequelize = new Sequelize({
        url: config.url,
        username:config.username,
        password:config.password,
        dialect: config.dialect
      })
    }
    if(sequelize){
      // 扫描模型文件夹,自动装配数据对象
      let modelFiles = fse.readdirSync(path.join(__dirname,'..', config.models || 'models'))
      modelFiles.forEach(modelFile=>{
         require(path.join(__dirname,'..', config.models || 'models',modelFile))(sequelize,DataTypes)
      })
      await sequelize.sync()
      map.set(name,sequelize)
    }
  })
  return map
}

引入使用

js 复制代码
const createDataSources = require('./data-source')
/**
 * create dataSources
 * @type {Map<any, any>}
 */
const dataSources = createDataSources(config['datasource'])
相关推荐
天下代码客9 小时前
使用electronc框架调用dll动态链接库流程和避坑
前端·javascript·vue.js·electron·node.js
weixin199701080169 小时前
【性能提升300%】仿1688首页的Webpack优化全记录
前端·webpack·node.js
不倒翁玩偶11 小时前
npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。
前端·npm·node.js
一心赚狗粮的宇叔12 小时前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
-嘟囔着拯救世界-13 小时前
【2026 最新版】OpenAI 祭出王炸 GPT-5.3-Codex!Win11 + VSCode 部署保姆级教程
vscode·gpt·chatgpt·node.js·node·codex·gpt5
全栈前端老曹1 天前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
行者无疆_ty1 天前
什么是Node.js,跟OpenCode/OpenClaw有什么关系?
人工智能·node.js·openclaw
-凌凌漆-1 天前
【npm】npm的-D选项介绍
前端·npm·node.js
lucky67071 天前
Windows 上彻底卸载 Node.js
windows·node.js
Android系统攻城狮1 天前
鸿蒙系统Openharmony5.1.0系统之解决编译时:Node.js版本不匹配问题(二)
node.js·鸿蒙系统·openharmony·编译问题·5.1