如何解决Erlang Mnesia的嵌套交易已终止
| 我有以下代码:J = fun()->mnesia:clear_table(names) end.
mnesia:activity(transaction,J,[],mnesia_frag).
我得到这个错误:
** exception exit: {aborted,{aborted,nested_transaction}}
我可以跑
mnesia:clear_table(names)
但是由于表名分散在几个节点上,我认为我必须使用mnesia_frag模块。
我究竟做错了什么 ?以及如何正确?
谢谢。
解决方法
您是正确的,mnesia:clear_table(names)不会清除整个碎片表。
mnesia:clear_table / 1已经在事务内运行,因此不能与mnesia:activity事务AccessContext一起使用。
而是尝试:
mnesia:activity(sync_dirty,fun mnesia:clear_table/1,[names],mnesia_frag).
如果您查看mnesia_frag.erl中的源代码,您会发现它只是在每个单独的表上调用mnesia:clear_table / 1。假设有4个碎片,则以上内容基本上等同于:
[mnesia:clear_table(T) || T <- [names,names_frag2,names_frag3,names_frag4]].
表名称来自:
mnesia_frag:frag_names(names).
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。