当前位置: 首页 > news >正文

orm2 中文文档 3.1 模型属性

译者:飞龙

来源:Model Properties

模型和一些关联具有一个或多个属性,每个属性有类型以及一些可选设置,你可以自行选择它们(或使用默认设置)。

类型

受支持的类型是:

  • text:文本字符串;

  • number:浮点数。你可以指定size2 | 4 | 8

  • integer:整数。你可以指定size2 | 4 | 8

  • booleantruefalse的值;

  • date:日期对象。你可以指定timetrue

  • enum:一个备选列表中的值;

  • object:JSON对象;

  • point:N维的点(不被广泛支持);

  • binary:二进制数据;

  • serial:自增长的整数,用于主键。

每个类型都有额外的选项。这个模型定义使用了它们中的绝大多数:

var Person = db.define("person", {
    name    : { type: "text", size: 50 },
    surname : { type: "text", defaultValue: "Doe" },
    male    : { type: "boolean" },
    vat     : { type: "integer", unique: true },
    country : { type: "enum", values: [ "USA", "Canada", "Rest of the World" ] },
    birth   : { type: "date", time: false }
});

所有类型都支持required(布尔值),unique(布尔值)和defaultValue(文本)。文本类型也支持最大尺寸(数值)和big(布尔值,用于非常长的字符串)。数值类型是浮点数,支持size(数值,字节大小)和unsigned(布尔值)。日期类型支持time(布尔值)。

要注意8字节的数值有其局限性。

如果你打算用默认选项,你可以使用原生类型来指定属性类型:

var Person = db.define("person", {
    name    : String,
    male    : Boolean,
    vat     : Number, // FLOAT
    birth   : Date,
    country : [ "USA", "Canada", "Rest of the World" ],
    meta    : Object, // JSON
    photo   : Buffer  // binary
});

将ORM字段映射到不同名称的数据库列中

var Person = db.define("person", {
    name    : { type: 'text', mapsTo: 'fullname' }
});

ORM属性name映射person表的fullname列。

自定义类型

你可以向ORM添加你自己的类型,像这样:

db.defineType('numberArray', {
  datastoreType: function(prop) {
    return 'TEXT'
  },
  // This is optional
  valueToProperty: function(value, prop) {
    if (Array.isArray(value)) {
      return value;
    } else {
      return value.split(',').map(function (v) {
        return Number(v);
      });
    }
  },
  // This is also optional
  propertyToValue: function(value, prop) {
    return value.join(',')
  }
});
var LottoTicket = db.define('lotto_ticket', {
  numbers: { type: 'numberArray' }
});

一些可用的高级自定义类型,能够让你像 PostGIS 那样使用模型。请见这个 spec 。

相关文章:

  • 点击复选框添加或删除value值到input输入框中
  • Android Property Animation属性动画:rotation旋转(2)
  • linux上很方便的上传下载文件工具rz和sz使用介绍
  • 2016.1.13 随笔
  • JMeter基础之一 一个简单的性能测试
  • [Java开发之路](14)反射机制
  • MDEV Primer
  • 闹心的变量
  • [转载]项目风险管理七种武器-碧玉刀
  • 会声会影简易相册制作教程
  • Spark学习之基于MLlib的机器学习
  • zabbix在centos6下的编译安装
  • C语言 百炼成钢1
  • 【Linux】环境变量设置
  • Apache安装教程
  • [数据结构]链表的实现在PHP中
  • Bootstrap JS插件Alert源码分析
  • Docker入门(二) - Dockerfile
  • js写一个简单的选项卡
  • node入门
  • spark本地环境的搭建到运行第一个spark程序
  • vue2.0开发聊天程序(四) 完整体验一次Vue开发(下)
  • 代理模式
  • 服务器从安装到部署全过程(二)
  • 坑!为什么View.startAnimation不起作用?
  • 前端学习笔记之观察者模式
  • 容器化应用: 在阿里云搭建多节点 Openshift 集群
  • 译有关态射的一切
  • 源码之下无秘密 ── 做最好的 Netty 源码分析教程
  • Nginx实现动静分离
  • 分布式关系型数据库服务 DRDS 支持显示的 Prepare 及逻辑库锁功能等多项能力 ...
  • $.type 怎么精确判断对象类型的 --(源码学习2)
  • $L^p$ 调和函数恒为零
  • (07)Hive——窗口函数详解
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (动手学习深度学习)第13章 计算机视觉---图像增广与微调
  • (附源码)计算机毕业设计SSM智慧停车系统
  • (一)eclipse Dynamic web project 工程目录以及文件路径问题
  • (转)PlayerPrefs在Windows下存到哪里去了?
  • .NET CORE 第一节 创建基本的 asp.net core
  • .net core使用ef 6
  • .net 设置默认首页
  • .NET6 命令行启动及发布单个Exe文件
  • .NET牛人应该知道些什么(2):中级.NET开发人员
  • .net下简单快捷的数值高低位切换
  • .net知识和学习方法系列(二十一)CLR-枚举
  • .vue文件怎么使用_我在项目中是这样配置Vue的
  • @Query中countQuery的介绍
  • [ 常用工具篇 ] AntSword 蚁剑安装及使用详解
  • [2019.3.5]BZOJ1934 [Shoi2007]Vote 善意的投票
  • [Android View] 可绘制形状 (Shape Xml)
  • [asp.net core]project.json(2)
  • [BROADCASTING]tensor的扩散机制
  • [C# 开发技巧]实现属于自己的截图工具
  • [C/C++]数据结构----顺序表的实现(增删查改)