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-extract的使用实例
Nov 18 NodeJs
nodejs文件操作模块FS(File System)常用函数简明总结
Jun 05 NodeJs
抛弃Nginx使用nodejs做反向代理服务器
Jul 17 NodeJs
Nodejs极简入门教程(三):进程
Oct 27 NodeJs
nodejs 提示‘xxx’ 不是内部或外部命令解决方法
Nov 20 NodeJs
Nodejs进阶:如何将图片转成datauri嵌入到网页中去实例
Nov 21 NodeJs
Nodejs下用submit提交表单提示cannot post错误的解决方法
Nov 21 NodeJs
详解nodejs中exports和module.exports的区别
Feb 17 NodeJs
NodeJS链接MySql数据库的操作方法
Jun 27 NodeJs
Nodejs连接mysql并实现增、删、改、查操作的方法详解
Jan 04 NodeJs
使用koa-log4管理nodeJs日志笔记的使用方法
Nov 30 NodeJs
Nodejs让异步变成同步的方法
Mar 02 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
PHP中的日期及时间
2006/11/23 PHP
探讨多键值cookie(php中cookie存取数组)的详解
2013/06/06 PHP
解析PHP将对象转换成数组的方法(兼容多维数组类型)
2013/06/21 PHP
php采集自中央气象台范围覆盖全国的天气预报代码实例
2015/01/04 PHP
php使用Cookie控制访问授权的方法
2015/01/21 PHP
thinkPHP3.1验证码的简单实现方法
2016/04/22 PHP
利用Laravel生成Gravatar头像地址的优雅方法
2017/12/30 PHP
利用谷歌地图API获取点与点的距离的js代码
2012/10/11 Javascript
Javascript removeChild()删除节点及删除子节点的方法
2015/12/27 Javascript
node.js微信公众平台开发教程
2016/03/04 Javascript
微信小程序 input输入框详解及简单实例
2017/01/10 Javascript
基于JavaScript实现选项卡效果
2017/07/21 Javascript
webpack配置之后端渲染详解
2017/10/26 Javascript
基于javascript中的typeof和类型判断(详解)
2017/10/27 Javascript
详解封装基础的angular4的request请求方法
2018/06/05 Javascript
从0到1搭建element后台框架优化篇(打包优化)
2019/05/12 Javascript
vue自定义树状结构图的实现方法
2020/10/18 Javascript
[50:59]2018DOTA2亚洲邀请赛 4.7 总决赛 LGD vs Mineski第四场
2018/04/10 DOTA
python支持断点续传的多线程下载示例
2014/01/16 Python
Python中return语句用法实例分析
2015/08/04 Python
python实现SOM算法
2018/02/23 Python
python psutil监控进程实例
2019/12/17 Python
keras得到每层的系数方式
2020/06/15 Python
英国精品买手店:Browns Fashion
2016/09/29 全球购物
Zavvi荷兰:英国大型音像制品和图书游戏零售商
2018/03/22 全球购物
社区中秋节活动方案
2014/01/29 职场文书
工作表现自我评价
2014/02/08 职场文书
群众路线党课主持词
2014/04/01 职场文书
《北京的春节》教学反思
2014/04/07 职场文书
兴趣小组活动总结
2014/05/05 职场文书
优秀教师自我评价范文
2014/09/27 职场文书
简单的个人租房协议书范本
2014/11/26 职场文书
岗位职责范本大全
2015/02/26 职场文书
签证工作证明模板
2015/06/15 职场文书
婚育证明格式
2015/06/17 职场文书
护理工作心得体会
2016/01/22 职场文书