nodejs使用Sequelize框架操作数据库的实现


Posted in NodeJs onOctober 21, 2020

sequelize.define

使用该方法可以定义model,例子如下:

const Sequelize = require('sequelize');

var sequelize = new Sequelize(config.database, config.username, config.password, {
 host: config.host,
 dialect: 'mysql',
 pool: {
  max: 5,
  min: 0,
  idle: 30000
 }
});

var Website = sequelize.define('website', {
 id: {
  type: Sequelize.BIGINT,
  primaryKey: true,
  autoIncrement: true
 },
 url: Sequelize.STRING(255),
 title: Sequelize.STRING(255),
 status: Sequelize.INTEGER,
 delete_mark: Sequelize.BOOLEAN
}, {
 timestamps: false
});

该方法传入的第一个参数是数据表的单数形式,怎么理解呢?例如这里传入的是website其实是模型名,数据表默认是websites这样的复数形式,这种约定我在Laravel中也碰见过,

也就是常说的,约定大于定义,也就是说,如果我们都按照约定的规范去开发,那么效率其实比重新定义,要高很多。

那么,定义好了模型,该怎么进行使用呢?

(async () => {
 let demo = await Website.create({
  url:'http://www.xxxx.com/',
  title:'demo'
 });
 console.log(demo);
})();

继承Model

const {Sequelize, DataTypes, Model} = require('sequelize');
const config = require('../config');

const sequelize = new Sequelize(config.database, config.username, config.password, {
 host: config.host,
 dialect: 'mysql',
 pool: {
  max: 5,
  min: 0,
  idle: 30000
 }
});

/**
 * @author chaojilaji
 * 数据表websites的关系对象映射
 */
class WebSite extends Model {

}

WebSite.init({
 id: {
  type: Sequelize.BIGINT,
  primaryKey: true,
  autoIncrement: true
 },
 url: Sequelize.STRING(255),
 title: Sequelize.STRING(255),
 status: Sequelize.INTEGER,
 delete_mark: Sequelize.BOOLEAN
}, {
 sequelize,
 modelName: 'Website',
 timestamps:false
});

(async () => {
 await sequelize.sync();
 let x = await WebSite.create({
  url: 'http://www.xxxxxxxx.com/',
  title: 'demo2'
 });
 console.log(x);
})();

module.exports = WebSite;

我比较推荐使用继承Model这种方式,通过创建一个class,这样可以使用model.exports=模块名的方式,将该模型封装起来。供别的地方使用,只需要require进去即可。

具体如何对数据表进行操作,就比较简单了,只需要参考API即可。 sequelize文档地址

到此这篇关于nodejs使用Sequelize框架操作数据库的实现的文章就介绍到这了,更多相关nodejs Sequelize操作数据库内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

NodeJs 相关文章推荐
NodeJS url验证(url-valid)的使用方法
Nov 18 NodeJs
nodejs之请求路由概述
Jul 05 NodeJs
轻松创建nodejs服务器(8):非阻塞是如何实现的
Dec 18 NodeJs
快速掌握Node.js之Window下配置NodeJs环境
Mar 21 NodeJs
nodejs连接mongodb数据库实现增删改查
Dec 01 NodeJs
基于NodeJS+MongoDB+AngularJS+Bootstrap开发书店案例分析
Jan 12 NodeJs
nodejs获取微信小程序带参数二维码实现代码
Apr 12 NodeJs
nodejs个人博客开发第六步 数据分页
Apr 12 NodeJs
nodejs入门教程四:URL相关模块用法分析
Apr 24 NodeJs
详解使用nodeJs安装Vue-cli
May 17 NodeJs
详解nodejs微信jssdk后端接口
May 25 NodeJs
Mac 安装 nodejs方法(图文详细步骤)
Oct 30 NodeJs
用Nodejs实现在终端中炒股的实现
Oct 18 #NodeJs
Nodejs在局域网配置https访问的实现方法
Oct 17 #NodeJs
NodeJS开发人员常见五个错误理解
Oct 14 #NodeJs
浅谈vue websocket nodeJS 进行实时通信踩到的坑
Sep 22 #NodeJs
基于NodeJS开发钉钉回调接口实现AES-CBC加解密
Aug 20 #NodeJs
浅谈使用nodejs搭建web服务器的过程
Jul 20 #NodeJs
通过实例了解Nodejs模块系统及require机制
Jul 16 #NodeJs
You might like
DC《小丑》11项提名领跑奥斯卡 Netflix成第92届奥斯卡提名最大赢家
2020/04/09 欧美动漫
比较时间段一与时间段二是否有交集的php函数
2011/05/31 PHP
php模拟socket一次连接,多次发送数据的实现代码
2011/07/26 PHP
不使用php api函数实现数组的交换排序示例
2014/04/13 PHP
PHP中使用strpos函数实现屏蔽敏感关键字功能
2014/08/21 PHP
PHP正则表达式匹配替换与分割功能实例浅析
2017/02/04 PHP
PHP消息队列实现及应用详解【队列处理订单系统和配送系统】
2019/05/20 PHP
JScript 脚本实现文件下载 一般用于下载木马
2009/10/29 Javascript
简单的代码实现jquery定时器
2013/11/17 Javascript
查找Oracle高消耗语句的方法
2014/03/22 Javascript
jQuery动画效果相关方法实例分析
2015/12/31 Javascript
jquery自定义插件——window的实现【示例代码】
2016/05/06 Javascript
详解JS对象封装的常用方式
2016/12/30 Javascript
vue绑定的点击事件阻止冒泡的实例
2018/02/08 Javascript
vue-cli3中vue.config.js配置教程详解
2019/05/29 Javascript
js设计模式之单例模式原理与用法详解
2019/08/15 Javascript
javascript 设计模式之享元模式原理与应用详解
2020/04/08 Javascript
JS实现简单贪吃蛇小游戏
2020/10/28 Javascript
在vue中使用eslint,配合vscode的操作
2020/11/09 Javascript
python获取元素在数组中索引号的方法
2015/07/15 Python
Python如何获取系统iops示例代码
2016/09/06 Python
Python编程使用tkinter模块实现计算器软件完整代码示例
2017/11/29 Python
Python编程实现的简单神经网络算法示例
2018/01/26 Python
Python Web程序部署到Ubuntu服务器上的方法
2018/02/22 Python
Python Logging 日志记录入门学习
2018/06/02 Python
基于python实现对文件进行切分行
2020/04/26 Python
css3 伪类选择器快速复习小结
2019/09/10 HTML / CSS
html5构建触屏网站之touch事件介绍
2013/01/07 HTML / CSS
AmazeUI 图标的示例代码
2020/08/13 HTML / CSS
美体小铺英国官网:The Body Shop英国
2017/01/24 全球购物
吉列剃须刀英国官网:Gillette英国
2019/03/28 全球购物
马耳他航空公司官方网站:Air Malta
2019/05/15 全球购物
简述索引存取方法的作用和建立索引的原则
2013/03/26 面试题
如何理解transaction事务的概念
2015/05/27 面试题
大学生表扬信范文
2014/01/09 职场文书
春季运动会开幕词
2015/01/28 职场文书