设为首页 收藏本站
查看: 1147|回复: 0

[经验分享] Node.js ORM 框架 sequelize 实践

[复制链接]

尚未签到

发表于 2017-2-25 09:42:52 | 显示全部楼层 |阅读模式
  最近在做团队的一个内部系统,这次使用的nodejs web框架是团队统一的hapi.js,而数据库依然是mysql,ORM 框架选用有着6000+ stars 的 sequelize.js,hapi-sequelize插件对sequelize做了很简单的封装,可以让我们很自如地在hapi中游走,比如配置和调用。

初始化 sequelize
// server.js  
const Hapi = require('hapi');
  
const server = new Hapi.Server();
  

  
//注册到 hapi server
  
server.register(
  [
  {
  register: require('hapi-sequelize'),
  options: {
  database: '',
  user: '',
  pass: '',
  dialect: 'mysql',
  port: 3306,
  models: 'Models/**/*.js',
  sequelize: {
  define: {
  underscoredAll: true
  }
  }
  }
  },
  ], (err) => {
  if (err) {
  console.error('failed to load plugin');
  }
  }
  
);

定义数据模型
// Models/user.js  
function userModel(sequelize, DataTypes) {
  var User = sequelize.define('User', {
  user_name: { //定义User表中的每一个字段
  type: DataTypes.STRING, //字段数据类型
  allowNull: false //是否允许为空
  },
  user_level: {
  type: DataTypes.INTEGER,
  allowNull: false
  },
  user_proj: {
  type: DataTypes.STRING
  }
  });
  

  return User;
  
}
  

  
module.exports = userModel;

同步模型到数据库
// server.js  
server.plugins['hapi-sequelize']
  .db.sequelize.sync().then(function () {
  console.log('models synced');
  });
  
//sync方法如果配置{force: true}时,如果数据库是否有该表,如果有则会删除表,再重建。

使用模型
  经过配置后,我们可以在路由handler中使用这个实例:
// Route/index.js  
function index(req, res) {
  var models = req.server.plugins['hapi-sequelize'].db.sequelize.models;
  models.User.find({...}).then({...});
  
}
  

  
module.exports = {
  method: 'GET',
  path: '/',
  handler: index
  
}];

新增一条记录
models.User.create({  user_name: 'John',
  user_level: 9
  
}).then((data) => {
  //...
  
});

查询记录
var user = models.User.findOne({  //...
  
}).then((data) => {
  //...
  
});
  
这是一个异步过程,sequelize 内部使用了 bluebird 对异步流程控制。变量user得到的是 Promise 对象,并非查询结果。

删除记录
models.User.destroy({  where: {
  id: 1
  }
  
}).then(function(rowDeleted) {
  if(rowDeleted === 0){
  console.log('成功删除记录');
  }
  
}, function(err){
  console.log(err);
  
});
  

  
//软删除操作:
  
// models.User.destroy({where: {id: userId}}, {force: false});
  
// 恢复软删除,使用 restore 方法 http://sequelize.readthedocs.org/en/latest/api/instance

多表查询
  要实现用户权限管理的RBAC模型,那需使用到多表查询,其实就是数据库中的association:
//1:1  
// user model
  
var user = sequelize.define('User', {/*attribute*/});
  
User.hasOne(userInfo);
  

  
// userInfo model
  
var userInfo = sequelize.define('userInfo', {/*attribute*/});
  
userInfo.belongsTo(User);
  

  
// 查
  
var userInfo = yield user.getUserInfo();

自定义SQL
  当业务较复杂时,sequelize 有可能无法满足你的需求,你可以编写自己的SQL语句:
var sequelize = req.server.plugins['hapi-sequelize'].db.sequelize;  

  
sequelize.query('SELECT * ...');

参考资料
  http://docs.sequelizejs.com/
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-346885-1-1.html 上篇帖子: React数据传递 下篇帖子: Darren_聂微东 - 关注前端技术完成《前端攻略系列》仅仅是第一步...
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表