文档章节

【sequelizejs实战】sequelizejs -DataTypes 添加OBJECTID类型

satanrabbit
 satanrabbit
发布于 2015/04/20 16:41
字数 767
阅读 1009
收藏 4
点赞 0
评论 0

#sequelizejs -DataTypes 添加OBJECTID类型

##概述

在数据库的主键的编码上,sequelizejs支持自增和uuid等方式,但这些主键的定义都各有优缺点,在使用过MongoDB之后,十分欣赏mongoDB的ObjectId生成的方式,以此作为主键对于分布式的应用更加友好,因此将sequelizejs 拓展,进行支持objectID。

##引入BSON

在项目中引入BSON,建议在sequelizejs目录中进行安装。

npm install BSON -save

BSON 安装后会即时编译。因此需要提前安装编译所需的环境。

##拓展DataTypes

在data-type.js中添加代码:

/**
 * A column storing a OBJECTID univeral identifier.
 * @property OBJECTID
 */
var OBJECTID = function() {
  if (!(this instanceof OBJECTID)) return new OBJECTID();
  ABSTRACT.apply(this, arguments);
};
util.inherits(OBJECTID, ABSTRACT);

OBJECTID.prototype.key = OBJECTID.key = 'OBJECTID';

【更新2016-2-14】

最新版本更新,后在此处设置toSql方法,继续添加如下代码:

OBJECTID.prototype.toSql = function() {
  return 'VARCHAR(24) BINARY';
};

设置模块接口:

module.exports = {
   ....
  OBJECTID:OBJECTID,
  ....
};

设置数据类型默认值

在utils.js中引入Bson模块:

  var Bson=require('bson');

在utils.js中修改toDefaultValue方法:

  if (typeof value === 'function') {
      var tmp = value();
      if (tmp instanceof DataTypes.ABSTRACT) {
        return tmp.toSql();
      } else {
        return tmp;
      }
    } else if (value instanceof DataTypes.UUIDV1) {
      return uuid.v1();
    } else if (value instanceof DataTypes.UUIDV4) {
      return uuid.v4();
    } else if (value instanceof DataTypes.NOW) {
      return Utils.now();
    } else if (value instanceof DataTypes.OBJECTID) {
      return Bson.ObjectID().toString();
    } else {
      return value;
    }

同时将OBJECTID作为默认值时候不设置数据库的默认值,更改utils.js的defaultValueSchemable方法:

  /**
   * Determine if the default value provided exists and can be described
   * in a db schema using the DEFAULT directive.
   *
   * @param  {*} value Any default value.
   * @return {boolean} yes / no.
   */
  defaultValueSchemable: function(value) {
    if (typeof value === 'undefined') { return false; }

    // TODO this will be schemable when all supported db
    // have been normalized for this case
    if (value instanceof DataTypes.NOW) { return false; }

    if (value instanceof DataTypes.UUIDV1 ||
      value instanceof DataTypes.UUIDV4||
      value instanceof DataTypes.OBJECTID) { return false; }

    if (lodash.isFunction(value)) {
      return false;
    }

    return true;
  },

在model.js中更新model定义时的refreshAttributes方法,约776行的 *definition.defaultValue === DataTypes.UUIDV4 * 后添加或条件:

  ||definition.defaultValue === DataTypes.OBJECTID 

【更新2016-2-14】

最新版本更新后不在model.js中进行设置refreshAttributes,更改为在sequelize.js中进行设置, 在Sequelize.prototype.normalizeAttribute 方法内更改为:

if (attribute.hasOwnProperty('defaultValue')) {
    if (typeof attribute.defaultValue === 'function' && (
        attribute.defaultValue === DataTypes.NOW ||
        attribute.defaultValue === DataTypes.UUIDV1 ||
        attribute.defaultValue === DataTypes.UUIDV4 ||
        attribute.defaultValue === DataTypes.OBJECTID
    )) {
      attribute.defaultValue = new attribute.defaultValue();
    }

mysql中添加OBJECTID的默认类型

在 lib/dialects/mysql.js中的UUID.prototype.toSql的定义后添加:


UUID.prototype.toSql = function() {
  return 'CHAR(36) BINARY';
};

var OBJECTID = function() {
  if (!(this instanceof OBJECTID)) return new OBJECTID();
  BaseTypes.OBJECTID.apply(this, arguments);
};
util.inherits(OBJECTID, BaseTypes.OBJECTID);

OBJECTID.prototype.toSql = function() {
  return 'VARCHAR(24) BINARY';
};

修改module.exports为:

module.exports = {
  UUID: UUID,
  OBJECTID:OBJECTID
};

【更新2016-2-14】

最新版本更新后无需设置toSql方法,无需以上设置。但需要设置默认的对应的数据类型。 在lib/dialects/mysql/data-type.js 的23行左右添加:

BaseTypes.OBJECTID.types.mysql = ['VAR_STRING'];

同时在lib/dialects/mssql/data-type.js、lib/dialects/sqlite/data-type.js中进行相应的设置,可应用于mssql和sqlite中。

##使用

定义的数据模型的时候,指定typeDataTypes.STRING,设置defaultValueDataTypes.OBJECTID,插入数据库时候会将默认值生成OBJECTID格式的字符串;

module.exports = function(sequelize, DataTypes) {
  var User = sequelize.define("User", {
    id:{
      type: DataTypes.OBJECTID,
      defaultValue: DataTypes.OBJECTID,
      primaryKey: true, // 定义主键
      comment: "OBJECTID主键"
    },
    name: {
    	type:DataTypes.STRING, //字符串,默认长度 255,
      comment: "用户姓名"
    },
    account: {
      type:DataTypes.STRING,
       validate: {
        isEmail: {
          msg: "用户账号必须是邮箱!"
        },
      },
      comment: "用户账号,使用邮箱注册"
    },
    pwd: {
      type:DataTypes.STRING,
      comment: "用户密码,使用MD5"
    }
  );

  return User;
};

© 著作权归作者所有

共有 人打赏支持
satanrabbit
粉丝 4
博文 22
码字总数 9691
作品 0
河西
程序员
sequelize 基本用法

官网 http://docs.sequelizejs.com/en/latest/ 基于orm的框架 查询 sequelize 没有封装实例集合,所以查询返回是集合时,会是一个实例的数组,此时需要手动遍历去toJSON() db .bill .findAll(...

mosaic101 ⋅ 2016/03/15 ⋅ 0

node.js开发环境中基于sequelize对mysql基本操作的简单实例

注:以下代码经过测试,但不能保证在其他node.js环境中也能正常运行。 sequelize documents : http://sequelizejs.com/ [墙] npm install sequelize // 链接var Sequelize = require('sequel...

快捷键V ⋅ 2013/08/07 ⋅ 0

百度云分享爬虫

百度云分享爬虫项目 github上有好几个这样的开源项目,但是都只提供了爬虫部分,这个项目在爬虫的基础上还增加了保存数据,建立elasticsearch索引的模块,可以用在实际生产环境中,不过web模...

蓝猫163 ⋅ 2016/11/18 ⋅ 1

Java操作 spark读写mongodb

import com.mongodb.MongoClient; import com.mongodb.MongoClientURI; import com.mongodb.client.MongoDatabase; import com.mongodb.spark.MongoConnector; import com.mongodb.spark.Mon......

Baclk5 ⋅ 2016/12/21 ⋅ 1

聊聊视图层切面实现方案

前面发过一篇《谈谈应用层切面设计》,@HulkZ说看了好几遍也没看懂,然后我又拉他到小黑屋面壁思过了好几次;也有人关心个性与扩展性如何得到平衡;也有人说,悠然就会扯淡,如何实现呢?那么...

悠悠然然 ⋅ 2016/05/30 ⋅ 3

pymongo tutorial

原版英文文档 教程 这个教程只在介绍如何使用MongoDB和PyMongo 准备前提 在我们开始之前,首先确认你已经正确安装了PyMongo ,在python shell 中如果下面的命令没有报错,则证明安装正确 >>...

Hardlighting ⋅ 2015/04/21 ⋅ 0

【优达学城测评】MongoDB-数据类型(4)

MongoDB数据类型: *Date *Timestamp *ObjectId * 内嵌文档 *数组 BSON可以理解为在JSON基础上添加了一些新的数据类型,包括Date,正则表达式,对数值类型的更进一步划分等。 数据类型 类型编...

Betty__ ⋅ 2016/10/16 ⋅ 0

python操作mongodb数据库

一、MongoDB 数据库操作 连接数据库 连接指定IP的数据库 插入 用 save 也可以插入 更新 更新指定一条记录 更新多条记录 update() 有几个参数需要注意: 删除 remove() 用于删除单个或全部文档...

浅夏 ⋅ 2013/12/02 ⋅ 0

02-1.Mongodb基础知识

·文档是Mongodb中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具有表现力。 ·集合(collection)可以看作是一个拥有动态模式(dynamic schema)的表。 ·Mongodb的一个实例...

贵在坚持 ⋅ 2015/02/27 ⋅ 0

mongodb_修改器($inc/$set/$unset/$push/$pop/upsert...

对于文档的更新除替换外,针对某个或多个文档只需要部分更新可使用原子的更新修改器,能够高效的进行文档更新。更新修改器是中特殊的键, 用来指定复杂的操作,比如增加、删除或者调整键,还...

北方攻城师 ⋅ 2015/09/24 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Centos7重置Mysql 8.0.1 root 密码

问题产生背景: 安装完 最新版的 mysql8.0.1后忘记了密码,向重置root密码;找了网上好多资料都不尽相同,根据自己的问题总结如下: 第一步:修改配置文件免密码登录mysql vim /etc/my.cnf 1...

豆花饭烧土豆 ⋅ 今天 ⋅ 0

熊掌号收录比例对于网站原创数据排名的影响[图]

从去年下半年开始,我在写博客了,因为我觉得业余写写博客也还是很不错的,但是从2017年下半年开始,百度已经推出了原创保护功能和熊掌号平台,为此,我也提交了不少以前的老数据,而这些历史...

原创小博客 ⋅ 今天 ⋅ 0

LVM讲解、磁盘故障小案例

LVM LVM就是动态卷管理,可以将多个硬盘和硬盘分区做成一个逻辑卷,并把这个逻辑卷作为一个整体来统一管理,动态对分区进行扩缩空间大小,安全快捷方便管理。 1.新建分区,更改类型为8e 即L...

蛋黄Yolks ⋅ 今天 ⋅ 0

Hadoop Yarn调度器的选择和使用

一、引言 Yarn在Hadoop的生态系统中担任了资源管理和任务调度的角色。在讨论其构造器之前先简单了解一下Yarn的架构。 上图是Yarn的基本架构,其中ResourceManager是整个架构的核心组件,它负...

p柯西 ⋅ 今天 ⋅ 0

uWSGI + Django @ Ubuntu

创建 Django App Project 创建后, 可以看到路径下有一个wsgi.py的问题 uWSGI运行 直接命令行运行 利用如下命令, 可直接访问 uwsgi --http :8080 --wsgi-file dj/wsgi.py 配置文件 & 运行 [u...

袁祾 ⋅ 今天 ⋅ 0

JVM堆的理解

在JVM中,我们经常提到的就是堆了,堆确实很重要,其实,除了堆之外,还有几个重要的模块,看下图: 大 多数情况下,我们并不需要关心JVM的底层,但是如果了解它的话,对于我们系统调优是非常...

不羁之后 ⋅ 昨天 ⋅ 0

推荐:并发情况下:Java HashMap 形成死循环的原因

在淘宝内网里看到同事发了贴说了一个CPU被100%的线上故障,并且这个事发生了很多次,原因是在Java语言在并发情况下使用HashMap造成Race Condition,从而导致死循环。这个事情我4、5年前也经历...

码代码的小司机 ⋅ 昨天 ⋅ 2

聊聊spring cloud gateway的RetryGatewayFilter

序 本文主要研究一下spring cloud gateway的RetryGatewayFilter GatewayAutoConfiguration spring-cloud-gateway-core-2.0.0.RC2-sources.jar!/org/springframework/cloud/gateway/config/G......

go4it ⋅ 昨天 ⋅ 0

创建新用户和授予MySQL中的权限教程

导读 MySQL是一个开源数据库管理软件,可帮助用户存储,组织和以后检索数据。 它有多种选项来授予特定用户在表和数据库中的细微的权限 - 本教程将简要介绍一些选项。 如何创建新用户 在MySQL...

问题终结者 ⋅ 昨天 ⋅ 0

android -------- 颜色的半透明效果配置

最近有朋友问我 Android 背景颜色的半透明效果配置,我网上看资料,总结了一下, 开发中也是常常遇到的,所以来写篇博客 常用的颜色值格式有: RGB ARGB RRGGBB AARRGGBB 这4种 透明度 透明度...

切切歆语 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部