我定义了一个名为 log 的记录。我想创建一个名为 log_table 的mnesia表。当我尝试将记录写入表时,我得到 bad_type 错误,如下所示:

(node1@kitt)4> mnesia:create_table(log_table, [{ram_copies, [node()]}, 
                                               {attributes, record_info(fields, log)}]).
{atomic,ok}

(node1@kitt)5> mnesia:dirty_write(log_table, #log{id="hebelek"}).
** exception exit: {aborted,{bad_type,#log{id = "hebelek"}}}
in function  mnesia:abort/1

我错过了什么?

有帮助吗?

解决方案

默认情况下,假设记录名称与表名相同。

要解决这个问题,您应该将表命名为 log ,或者在表格选项中添加 {record_name,log} 选项(正如您在修复中所做的那样) )。

通常,将记录和表命名为相同的东西通常是一种好习惯,它使代码更易于阅读和调试。然后,您也可以使用 mnesia:write / 1 函数,仅将您的记录作为参数。然后,Mnesia通过查看名称来确定将记录放入哪个表格。

其他提示

我找到了。当我更改 mnesia:create_table 时调用此

mnesia:create_table(log_table, [{ram_copies, [node()]},
                                {record_name, log},
                                {attributes, record_info(fields, log)}]).

一切正常。

您对日志记录的定义如何?如果从头创建一个新表(即首先删除Mnesia @目录),是否会出现相同的错误。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top