database - 防止添加主键已存在于 mnesia 中的记录的最佳方法是什么?

标签 database erlang mnesia

假设我有一个简单的记录定义:

-record(data, {primary_key = '_', more_stuff = '_'}).

我想要一个简单的函数,将这些记录之一添加到 mnesia 数据库中。但如果已经有一个具有相同主条目的条目,我希望它失败 键。

(在下面的例子中,假设我已经定义了

db_get_data(Key)->
    Q = qlc:q([Datum
               || Datum = #data{primary_key = RecordKey}
                      <- mnesia:table(data),
                  RecordKey =:= Key]),
    qlc:e(Q).

)

下面的作品,但让我觉得有点丑......

add_data(D) when is_record(D, data)->
    {atomic, Result} = mnesia:transaction(fun()->
                                                  case db_get_data(D#data.primary_key) of
                                                      [] -> db_add_data(D);
                                                      _ -> {error, bzzt_duplicate_primary_key}
                                                  end
                                          end),

    case Result of
        {error, _} = Error -> throw(Error);
        _ -> result
    end.

这也行,但也很丑:

add_data(D) when is_record(D, data)->
    {atomic, Result} = mnesia:transaction(fun()->
                                                  case db_get_data(D#data.primary_key) of
                                                      [] -> db_add_data(D);
                                                      _ -> throw({error, bzzt_duplicate_primary_key})
                                                  end
                                          end).

和上面不同的是上面抛出

{error, bzzt_duplicate_primary_key},

而这个抛出

{error, {badmatch, {aborted, {throw,{error, bzzt_duplicate_primary_key}}}}}

那么:是否有一些约定来指示此类错误?或者是否有一种内置方法可以让 mnesia 为我抛出此错误?

最佳答案

我认为它们都很好,如果你只是让你的代码更漂亮,比如:

add_data(D) when is_record(D, data)->

    Fun = fun() ->
                  case db_get_data(D#data.primary_key) of
                      [] -> db_add_data(D);
                      _  -> throw({error, bzzt_duplicate_primary_key})
                  end
          end,

    {atomic, Result} = mnesia:activity(transaction, Fun).

add_data(D) when is_record(D, data)->

    Fun = fun() ->
                  case db_get_data(D#data.primary_key) of
                      [] -> db_add_data(D);
                      _  -> {error, bzzt_duplicate_primary_key}
                  end
          end,

    {atomic, Result} = mnesia:activity(transaction, Fun),

    case Result of
        {error, Error} -> throw(Error);
        _              -> result
    end.

你是抛出错误还是返回错误?我自己会返回一个错误。我们将代码分成 mnesia 工作单元——一个具有一组功能的模块,这些功能执行基本的 mnesia 事件,而不是在事务中,以及一个 api 模块,它将工作单元“组合”成 mnesia 事务,其功能看起来与上面的非常相似.

关于database - 防止添加主键已存在于 mnesia 中的记录的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/723680/

相关文章:

python - rabbitmq 队列填满了 celery 任务

ssl - 更新 Erlang 后从 SSL 混合 local.hex 失败

erlang - Mnesia 写入失败

python - MYSQL 更新另一个表中的数据(如果存在),否则插入

python - 无法将 DateTimeField 的默认值设置为 "0000-00-00 00:00:00"

scala - 名称值/表达式保存在函数程序中的什么位置?

sockets - erlang中socket如何通过数据包发送数据?

erlang - ejabberd集群,当master宕机时Slave不工作

sql - MDF (SQL) 数据库文件超过 88 GB,我不知道为什么!

可以处理半结构化数据的数据库?