Sequelize使用总结

栏目: 数据库 · 发布时间: 5年前

内容简介:sequelize是nodejs开发环境中的orm框架,基于promise,支持mysql,postgres,sqlite,Microsoft SQL Server.以下记录使用的一些心得体会:在java中如果不使用orm框架,我们会提前定义很多bean类(也叫Model类),然后编写sql查询语句从数据库中查询得到结果集,然后需要自己手动转换成bean类,而编写bean类和转换成bean类需要花费不少时间,而这些工作都是很琐碎,繁杂的,如果能自动生成则最好。Java也有orm框架,能够自动生成这些bea

sequelize是nodejs开发环境中的orm框架,基于promise,支持mysql,postgres,sqlite,Microsoft SQL Server.

以下记录使用的一些心得体会:

为什么使用orm框架

java 中如果不使用orm框架,我们会提前定义很多bean类(也叫Model类),然后编写 sql 查询语句从数据库中查询得到结果集,然后需要自己手动转换成bean类,而编写bean类和转换成bean类需要花费不少时间,而这些工作都是很琐碎,繁杂的,如果能自动生成则最好。Java也有orm框架,能够自动生成这些bean类,比如jooq.

使用sequlize的orm框架的理由:

  1. 减少在数据库中定义表的繁杂工作,可在代码中定义表结构及关联关系

  2. 可为Model类添加自定义方法,以及校验方法,防止不符合规则得数据

  3. 自动优化sql语句,可防注入

  4. 若表之间有关联关系,使用对象操作方法即可轻松创建,更新,查询关联的对象

  5. 在nodejs中查询数据,无须手动转换为bean类,也无需转换为json再发给客户端

如何优雅地使用sequelize

  1. 建议用Sequelize接管数据库表的创建工作

    在模型类中定义好字段,以及类型,然后使用sequelize的同步方法,将表的定义同步到数据库中,可自动在数据库中建立好表结构,并设置表之间的关系

    如果直接在数据库中定义表,然后使用sequelize-auto-import的方式将表结构转换成Model类也可行,但是不方便给Model类添加自定义方法,校验方法,以及表之间的关系,所以更推荐使用Sequelize接管数据库表的创建工作

  2. 自动添加常用字段

    表字段可自动添加create_time, update_time,deleted 等常用字段, 当然也可不用这些字段,但是大部分表其实都需要这些字段,可以减少大量重复工作

  3. 设置表之间的关联关系用处大

    若设置了表之间的关联关系 可很方便地创建,查询,更新关联数据

    只要设置了belongTo, hasOne, hasMany, belongsToMany关系,那么源对象就可拥有get,set方法来取关联关系的目标对象

    比如:

    GiftOrder.belongsTo(PayOrder, {
      foreignKey: 'order_no',
      as : 'payOrder'
    })

    那么GiftOrder的实例就有了getPayOrder,setPayOrder方法,甚至在创建GiftOrder对象时可跟一个PayOrder对象,写到数据库时可同时写入,另外查询GiftOrder时可使用 eager loading 的技术同时将关联的PayOrder对象拿到,非常方便

参考资料

sequelize官方文档


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

松本行弘的程式世界

松本行弘的程式世界

松本行弘 / 鄧瑋敦 / 博碩 / 2010年07月27日

讓Ruby之父教您大師級的程式思考術! 本書以松本行弘先生對程式本質的深層認知、各種技術之優缺點的掌握,闡述Ruby這套程式語言的設計理念,並由此延伸讓您一窺程式設計的奧妙之處。本書內含許多以Ruby、Lisp、Smalltalk、Erlang、JavaScript等動態語言所寫成的範例,從動態語言、函數式程式設計等領域開展您的學習視野。 本書精華: ‧物件導向與抽象化 ‧......一起来看看 《松本行弘的程式世界》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

MD5 加密
MD5 加密

MD5 加密工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具