@k3000/store 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,226 @@
1
+ **结构化存储工具**
2
+
3
+ ```
4
+ *1、低版本升级到1.3.0请执行upgrade和submit更新存储文件。
5
+ *2、1.5.0版本请注意page的用法。
6
+ *3、1.6.1修改String中文存储的BUG建议更新,更新请注意第1、2条和page的用法。
7
+ *4、1.7.0修复中文路径问题。
8
+ ```
9
+
10
+ **初始化和更新升级**
11
+
12
+ ```
13
+ import upgrade from 'dmb3'
14
+
15
+ const {appendSet, submit} = upgrade('test', {version: 1, password: '', newPwd: ''})
16
+
17
+ appendSet(/* */)
18
+
19
+ submit()
20
+ ```
21
+
22
+ 文件结构为:假设存储名为:test
23
+
24
+ ```
25
+ test ┳ 1.2 ┳ buffer ┳
26
+ ┃ ┃ ┇ // buffer格式或者文本格式的存储目录
27
+ ┃ ┃ ┗
28
+ ┃ ┣ data // 数据存储文件
29
+ ┃ ┣ index // 数据索引文件
30
+ ┃ ┗ index.mjs // 数据访问文件,可以通过该文件访问指定版本
31
+ ┣ ...
32
+ ┣ 3 ┳ ...
33
+ ┃ ┗ index.mjs // 数据访问文件,可以通过该文件访问指定版本
34
+ ┣ 4 ...
35
+ ┗ index.mjs // 默认入口文件,指向最新版本
36
+ ```
37
+
38
+ **数据类型**
39
+
40
+ 类型:Id, Uint, Int, Bool, Time, Float, String, Buffer, Text
41
+
42
+ ```
43
+ import upgrade, {
44
+ Bigint,
45
+ bigintSerialize,
46
+ BigUint,
47
+ Buffer,
48
+ Byte,
49
+ Float,
50
+ Id,
51
+ Int,
52
+ String,
53
+ Text,
54
+ Time,
55
+ Uint
56
+ } from 'dmb3'
57
+ const {appendSet, submit} = upgrade('test')
58
+ appendSet('user', {
59
+ uid: String,
60
+ pwd: String('存MD5指').length(32),
61
+ loginTime: Time().value(Time.update)
62
+ }, '用户表')
63
+ submit().then(() => console.log('完成'))
64
+ ```
65
+ 缺省写法与完整写法
66
+ ```
67
+ // Time.value(Time.update) 和 Time().value(Time.update) 两种写法一样。
68
+ /* 例如:
69
+ appendSet('test', {
70
+ id: Id,
71
+ })
72
+ 等价
73
+ appendSet('test', {
74
+ id: Id(),
75
+ })
76
+ */
77
+
78
+ // Id 用法
79
+ Id('备注') // 会补全默认值
80
+ Id()
81
+ .index(false) // 是否索引,此类型默认为 true
82
+ .value('2') // 默认值,此类型缺省为 1
83
+ .step(2) // 缺省自增值,此类型缺省为 1
84
+ .remark('备注') // 可缺省
85
+
86
+ // Uint 用法
87
+ Uint()
88
+ .index(false) // 是否索引,此类型默认为 false
89
+ .value(2) // 默认值,此类型没有缺省值
90
+ .step(2) // 缺省自增值,此类型没有缺省值
91
+ .remark('备注') // 可缺省
92
+
93
+ // Int 用法
94
+ Int()
95
+ .index(false) // 是否索引,此类型默认为 false
96
+ .value(2) // 默认值,此类型没有缺省值
97
+ .step(2) // 缺省自增值,此类型没有缺省值
98
+ .remark('备注') // 可缺省
99
+
100
+ // Bool 用法
101
+ Bool()
102
+ .index(false) // 是否索引,此类型默认为 false
103
+ .value(false) // 默认值,此类型缺省为 false
104
+ .remark('备注') // 可缺省
105
+
106
+ // Time 用法
107
+ Time()
108
+ .index(false) // 是否索引,此类型默认为 false
109
+ .value(Time.update) // 默认值,此类型没有缺省值,可取值:Time.update、Time.now
110
+ .remark('备注') // 可缺省
111
+
112
+ // Float 用法
113
+ Float()
114
+ .index(false) // 是否索引,此类型默认为 false
115
+ .value(0.1) // 默认值,此类型没有缺省值
116
+ .step(0.1) // 缺省自增值,此类型没有缺省值
117
+ .remark('备注') // 可缺省
118
+
119
+ // String 用法
120
+ String()
121
+ .index(false) // 是否索引,此类型默认为 false
122
+ .value('123456') // 默认值,此类型没有缺省值
123
+ .length(8) // 长度,此类型默认为 12
124
+ .remark('备注') // 可缺省
125
+
126
+ // Buffer 用法
127
+ Buffer().remark('备注') // 可缺省
128
+
129
+ // Text 用法
130
+ Text().remark('备注') // 可缺省
131
+ ```
132
+ 存储结构更新写法
133
+ ```
134
+ // 新增集合
135
+ appendSet('user', {
136
+ uid: String,
137
+ pwd: String('存MD5指').length(32)
138
+ }, '用户表')
139
+
140
+ // 更新集合备注
141
+ updateSetRemark('log', '日志表')
142
+
143
+ // 更新列
144
+ updateCol('user', {
145
+ loginTime: Time().value(Time.update).remark('登录时间')
146
+ })
147
+
148
+ // 更名操作
149
+ renameSet('test', 'test2')
150
+ renameCol('user', {
151
+ uid: 'usn',
152
+ test: 'test2',
153
+ })
154
+
155
+ // 删除操作
156
+ deleteSet('test2')
157
+ deleteCol('user', 'test2')
158
+
159
+ const {submit} = upgrade('test', {
160
+ version: 7,
161
+ password: '123123',
162
+ newPwd: '111111' // 新密码
163
+ })
164
+
165
+ submit()
166
+ ```
167
+ **打开使用已有存储文件**
168
+
169
+ **使用**
170
+ ```
171
+ import storage from './test/index.mjs' // 使用最新版本
172
+ import storage from './test/7/index.mjs'// 使用指定版本
173
+ import storage, {remark, getStruct} from './test/7/index.mjs' // 获取存储结构和集合备注
174
+ ```
175
+ 查:
176
+
177
+ ```
178
+ storage.admin.find(admin => admin.usn.includes('test')).role
179
+
180
+ if (storage.admin.indexByUid('admin')[0].pwd === '123456');
181
+
182
+ // 带索引的时间
183
+ storage.admin.indexByLoginTime(-Infinity, '2022/01/01')
184
+
185
+ // 简单分页查询
186
+ storage.admin.page(admin => predicate(admin), index, size)
187
+
188
+ // 结果缓存的分页查询,缓存10秒
189
+ const params = {key: 'name', index: 1, size: 10}
190
+ storage.admin.page(admin => predicate(admin), 'index', 'size', params)
191
+ // 联合查询 eachFlat类似LEFT JOIN,filterFlat类似INNER JOIN
192
+ storage.user.eachFlat(storage.userRole, (a, b) => a.userId === b.userId)
193
+ .filterFlat(storage.role, 'roleId')
194
+ ```
195
+
196
+ 增:
197
+
198
+ ```
199
+ storage.admin.push(
200
+ {
201
+ usn: 'admin',
202
+ pwd: '123456'
203
+ },
204
+ {
205
+ usn: 'test',
206
+ pwd: '123456'
207
+ }
208
+ )
209
+ ```
210
+
211
+ 改:
212
+
213
+ ```
214
+ storage.admin.find(admin => admin.usn === 'admin').role = 'root'
215
+ ```
216
+
217
+ 删:
218
+
219
+ ```
220
+ storage.admin.remove(...storage.admin.filter(admin => admin.usn.startsWith('test')))
221
+ ```
222
+ 更多使用方法参考 `test.mjs`
223
+
224
+ **保存:**
225
+
226
+ `storage.close()` // 关闭并保存