在 Lua 脚本中更改 Aerospike 数据库中映射类型记录中 bin 的值
2018-1-24 5:57:48
收藏:0
阅读:84
评论:2
假设 Aerospike 数据库拥有以下记录数据
假设命名空间为 employee
名称 年龄 特征
sachin 25 MAP('{"weight":70, "height":25}')
现在我想通过 Lua 脚本更改所有 employee 命名空间中的记录中 map 中高度的值。
我已经尝试过更改普通数据类型中 bins 的方法,例如更改年龄,如下所示:
function changeAgeOfEmployee(rec)
if not aerospike:exists(rec) then
error ("无效记录。返回")
return
else
age = 30
rec['age'] = age
aerospike:update(rec)
end
end
但我不知道如何在 Lua 中更改 map 中的值,有人可以给我提供帮助吗?
点赞
用户582436
如果要修改一个映射的键或列表的索引,应该将该 bin 强制转换为一个本地变量,然后在更新之前将其设置回记录。
function changes(rec)
rec['i'] = 99
local m = rec['m']
m['a'] = 66
rec['m'] = m
aerospike:update(rec)
end
在AQL中:
$ aql
Aerospike 查询客户端
版本 3.15.1.2
C 客户端版本 4.3.0
版权所有 2012-2017 Aerospike。保留所有权利。
aql> register module './test.lua'
OK,已添加 1 个模块。
aql> select * from test.demo where PK='88'
+----+-------+--------------------------------------+------------------------------------------+
| i | s | m | l |
+----+-------+--------------------------------------+------------------------------------------+
| 88 | "xyz" | MAP('{"a":2, "b":4, "c":8, "d":16}') | LIST('[2, 4, 8, 16, 32, NIL, 128, 256]') |
+----+-------+--------------------------------------+------------------------------------------+
1 行(用时 0.002 秒)
aql> execute test.changes() on test.demo where PK='88'
+---------+
| changes |
+---------+
| |
+---------+
1 行(用时 0.001 秒)
aql> select * from test.demo where PK='88'
+----+-------+---------------------------------------+------------------------------------------+
| i | s | m | l |
+----+-------+---------------------------------------+------------------------------------------+
| 99 | "xyz" | MAP('{"a":66, "b":4, "c":8, "d":16}') | LIST('[2, 4, 8, 16, 32, NIL, 128, 256]') |
+----+-------+---------------------------------------+------------------------------------------+
1 行(用时 0.000 秒)
2018-01-23 21:08:26
评论区的留言会收到邮件通知哦~
推荐文章
- Lua 虚拟机加密load(string.dump(function)) 后执行失败问题如何解决
- 我想创建一个 Nginx 规则,禁止访问
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?

你的
MAP数据类型基本上就是一个 Lua 表格。在 Lua 中,可以写成:local m = map {"weight" => 70, "height" => 25}要循环遍历所有的键/值对,可以使用 pairs 迭代器,就像这样:
for key, value in map.pairs(m) do m[key] = 30 --这会将你的 MAP 的所有值都更改为 30 end