Mnesia迭代:提供一组函数来迭代表里的所有记录,firecat实践

简介: Mnesia迭代:提供一组函数来迭代表里的所有记录,firecat实践

1、Mnesia提供了如下几个函数遍历所有记录


mnesia:foldl(Fun, Acc0, Tab) -> NewAcc | transaction abort
     mnesia:foldr(Fun, Acc0, Tab) -> NewAcc | transaction abort
     mnesia:foldl(Fun, Acc0, Tab, LockType) -> NewAcc | transaction abort
     mnesia:foldr(Fun, Acc0, Tab, LockType) -> NewAcc | transaction abort

这些函数会将Fun遍历应用到表Tab表上,并把结构放入累计集Acc0中,可以按需要指定锁类型。Fun有两个参数,第一个是从表中取出的记录,第二个是累计集。


例如要查找薪资级别在10以下的员工:

find_low_salaries() ->
     Constraint = 
          fun(Emp, Acc) when Emp#employee.salary < 10 ->
                 [Emp | Acc];
               (_, Acc) ->
                    Acc
             end,
        Find = fun() -> mnesia:foldl(Constraint, [], employee) end,
        mnesia:transaction(Find)


将薪资上调到10级,返回所有涨薪和:

increase_low_salaries() ->
         Increase = 
             fun(Emp, Acc) when Emp#employee.salary < 10 ->
                    OldS = Emp#employee.salary,
                    ok = mnesia:write(Emp#employee{salary = 10}),
                    Acc + 10 - OldS;
                (_, Acc) ->
                    Acc
             end,
        IncLow = fun() -> mnesia:foldl(Increase, 0, employee, write) end,
        mnesia:transaction(IncLow).

 

在遍历中可以做很多事情,但是要特别留意性能和内存消耗。



2、firecat的实践一,查询数据库表的某一列,并求和

get_onlinenum(<<"ALL_DEVICES">>) -> Mnesia迭代求和
    Sum =
  fun(Emp, Acc) when Emp#?ONLINE_TAB.onlinenum /= 0 ->
  V = Emp#?ONLINE_TAB.onlinenum,
        Acc + V;
  (_, Acc) ->
  Acc
  end,
    Find = fun() -> mnesia:foldl(Sum, 0, ?ONLINE_TAB) end,
    mnesia:transaction(Find);
(test@192.168.83.128)1> test:get_onlinenum(<<"ALL_DEVICES">>).
{atomic,2}


其中,{atomic,2}里面的2就是返回结果。


实践二,修改数据


clear_onlinenum() ->
    Clear =
  fun(Emp, Acc) when Emp#?ONLINE_TAB.onlinenum /= 0 ->
    ok = mnesia:write(Emp#?ONLINE_TAB{onlinenum = 0});
    (_, Acc) ->
    Acc
  end,
    Find = fun() -> mnesia:foldl(Clear, [], ?ONLINE_TAB) end,
    ret(mnesia:transaction(Find)).


相关文章
|
Oracle Java 关系型数据库
CentOS7 下rpm安装jdk1.8
CentOS7 下rpm安装jdk1.8
349 0
|
关系型数据库 Java Linux
拒坑版oVirt-Engine 4.2 编译笔记
如何用源码编译出一套oVirt-Engine 的介绍很多,其实官方档也介绍的很清楚,但是依然很多人在编译过程中各种踩坑、甚至怀疑人生。说实话前几天想个做编译笔记分享给大家的过程中又踩坑,因此坚定一定要写一个《拒坑版oVirt-Engine 4.
5348 0
|
Java Go Docker
docker 安装flowable/flowable-ui
docker 安装flowable/flowable-ui
1406 0
|
7月前
|
人工智能 大数据 物联网
申报开启|2025年阿里云协同育人项目申报指南
阿里云启动2025年协同育人项目申报,支持高校教学内容和课程体系改革及实践基地建设。项目涵盖人工智能通识教育、AIGC设计等领域,提供资金、云计算资源和技术培训等支持。申报截止至2025年2月28日,面向全国本科高校教师,旨在深化产教融合,共育创新人才。详情及流程见官网。
|
11月前
|
JavaScript 前端开发 Java
多种语言请求API接口方法
每种语言和库的选择取决于具体需求、项目环境以及个人偏好。了解这些基本方法,开发者就可以根据项目需求选择合适的语言和库来高效地与API交互。
247 1
|
12月前
|
人工智能 监控 搜索推荐
盘点几款助力企业销售数字化转型的CRM软件
在数字化时代,企业面临诸多挑战与机遇。数字化转型成为提升竞争力的关键路径,其中CRM软件发挥着核心作用。本文介绍了十款助力销售数字化转型的CRM软件,如销售易CRM、纷享销客、Zoho CRM等,它们各具特色,旨在帮助企业高效管理客户信息、优化销售流程,并通过数据分析提升市场竞争力。企业可根据自身需求选择合适的CRM软件,推动数字化转型,实现长期增长与成功。
|
应用服务中间件
SpringMVC系列之 javax.servlet.http.HttpServletRequest.getDispatcherType()Ljavax/servlet/DispatcherType;
文章讨论了在SpringMVC中遇到的`javax.servlet.http.HttpServletRequest.getDispatcherType()Ljavax/servlet/DispatcherType;`错误,并提供了通过升级Tomcat到8.x版本和检查pom依赖配置来解决这个问题的方法。
|
机器学习/深度学习 人工智能 Java
软件开发者必读!2024年30大趋势提前曝光!
软件是科技行业的基础。从智能手机到复杂的企业系统,软件是推动这些技术的核心。在探索数字时代的过程中,了解软件开发的趋势非常重要。人工智能、机器学习、物联网等技术的快速发展对软件开发行业产生了巨大影响。本文旨在通过30个数据汇总,帮助读者们初步了解2024年软件开发领域的新趋势。
|
关系型数据库 MySQL 程序员
老程序员分享:MySQL数据库企业级应用实践
老程序员分享:MySQL数据库企业级应用实践
|
人工智能 NoSQL atlas
MongoDB白皮书|应用程序驱动型智能:定义下一代成功的现代应用程序
MongoDB Atlas 开发者数据平台旨在帮助这两个团队“乘风破浪”,从而打造更快、更智能的应用和自动化业务流程,能够更快地对快速变化的操作数据做出反应和响应。
3373 0