sequelize 基本用法

官网

http://docs.sequelizejs.com/en/latest/

基于orm的框架

查询

sequelize 没有封装实例集合,所以查询返回是集合时,会是一个实例的数组,此时需要手动遍历去toJSON()

db
    .bill
    .findAll({where:{id:{lt:3}}})
    .then(result => result.map(v => v.toJSON()));

插入

db
    .bill
    .create({order_no:101,deal_way:1,reason:'payback'})

添加

db
    .bill
    .update({order_no:201,deal_way:1321,reason:'pay no back'},{where:{id:154}})
    .then(result => console.log(result))
    .catch(err => console.log(err));

删除

db
    .bill
    .findOne()
    .then(bill_instance => {         return bill_instance.destroy();
    })

事务

sequelize.transaction().then(t => {    return db.bill.create({order: 100001, deal_way : 'wadfads' }, {transaction: t})
        .then(()=> {return db.bill.create({order: 100002, deal_way: 'unpan' }, {transaction: t});})
        .then(()=>t.commit())
        .catch(()=>t.rollback());
    })
    .then(()=>console.log(' transaction done'))
    .catch(err=>console.log(err));

联表

user.js

//类方法
    classMethods: {
          associate: function(models) {this.hasOne(models.hlr_user,{foreignKey:'user_id'});}
    },

hlr_user.js

classMethods:{
        associate:function( models) { this.belongsTo(models.user,{foreignKey:'user_id'}); }
  }

调用

db
    .user
    .findOne({
        include    : [{model:db.hlr_user,attributes:['market_price']}],//与bookshelf不同的是这里不需要写外键
        attributes : ['usertype','name']
    })
    .then(result => console.log(result.toJSON()));


转载于:https://my.oschina.net/wjj328938669/blog/638009

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值