阿里云表格存储功能强大,因而API非常繁琐,在只需要完成简单的数据存储功能时非常麻烦。此项目对阿里云的表格存储Nodejs SDK进行简化封装,用一部分功能的代价换取简单方便的接口,方便敏捷开发。此项目省略的功能包括:
- 版本:不考虑多版本表格,也不考虑数据写入的时间戳。
- 表操作:不支持对表的操作,仅支持对数据的读写。
- 整数:整数数字会被自动转化为整数类型。
- 主键:默认使用一个主键
id
,但是支持自定义主键和多主键,请参考主键 - 多元索引:仅支持少数多元索引功能
npm i simple-aliyun-tablestore
为了支持函数计算等应用场景,在已经安装官方Nodejs SDK
tablestore
的前提下,您可以直接复制文件/SAT.js
,并通过require('./SAT.js')
的方式引入。
const SAT = require('simple-aliyun-tablestore')
SAT.init('endpoint', 'instance', 'akId', 'akSecret')
async function test () {
const table = SAT('tablename')
await table.put('rowid', { hello: 'world!' })
const res = await table.get('rowid')
console.log(res)
}
test()
新增了短的常量符号,与官方常量的对照关系如下:(官方的常量依然支持)
I IGNORE
E EXPECT_EXIST
NE EXPECT_NOT_EXIST
== EQUAL
!= NOT_EQUAL
> GREATER_THAN
>= GREATER_EQUAL
< LESS_THAN
<= LESS_EQUAL
! NOT
&& AND
|| OR
条件变量c
可以描述行的存在条件,也可以同时描述列条件。常规情况下,c
是一个如下格式的数组:
c = ['E', ['num', '==', 10], ['space', '>', 10]]
数组首个元素是字符串,指定期望的行条件。从第二个元素开始,每个元素是一个长度为3的数组,描述一个列条件。多个列条件默认使用逻辑与连接。
上述例子中的条件表示:期望行存在 and num属性值等于10 and space属性值大于10
当不需要列条件时,条件变量c
可以省略为一个字符串,描述期望的行条件。
若需要多个主键或自定义主键,需要在生成表的操作对象时指定,并在传入主键时按顺序传入数组,例如:
const opt = SAT('tablename', ['pk1', 'pk2'])
const res = await opt.get(['pk1value', 123])
const SAT = require('simple-aliyun-tablestore')
// 初始化
SAT.init('endpoint', 'instancename', 'accessKeyId', 'accessKeySecret', 'securityToken')
// 访问原始client对象,若传入c,则使用c替换client
SAT.client(c)
// utils
SAT.utils = { parseInt(v), condition(c), pk(k, pks), params(k, c, t, pks), wrap(k, row, pks), wrapRows(rows, pks, res), columns(attrs), attrColumns(attrs) }
调用SAT('tablename')
生成操作对象。
// 查询单行数据
SAT('tablename').get('id', cols = [])
// 覆盖单行数据
SAT('tablename').put('id', { keys: 'values' }, c = 'I')
// 删除单行数据
SAT('tablename').del('id', c = 'I')
// 扫描连续的主键
// 返回对象,键为行对应的主键逗号连接,值为行数据对象
SAT('tablename').getRange('startid', 'endid', cols = [])
// 批量读取,自动分片
// 返回对象,键为行对应的主键逗号连接,值为行数据对象
SAT('tablename').getBatch(['id1', 'id2', 'id3'], cols = [])
// 更新
// u为更新内容:
// 若u不为对象,则理解为更新属性值
// 若u为对象且u.del为真,则删除此属性
// 若u为对象且u.inc存在,则自增此属性,步长为u.inc
SAT('tablename').update('id', { 'keyToUpdate': u }, c = 'I')
// 批量写入,自动分片
// 接受数组,每个项目为一个数组描述一个写入操作
// 写入操作的第一个项目为写入类型,支持put(PUT), update(UPDATE), del(DELETE)
// 第二个项目开始,与update, put, del的参数一致
SAT('tablename').writeBatch([
['put', 'id1', { hello: 'hi' }, 'I'],
['update', 'id2', { hello: { del: 1 } }],
['del', 'id3']
])
// 多元索引
// 目前仅支持精确匹配
SAT('tablename').search('index', ['fieldName', 'value'])