我已经完成了以下操作。我已经存储了如下的详细信息,但即使我在mapreduce中收到错误,请帮助我。我想要test_age存储桶的数据。显示{gopi,1}。
1> {ok, Pid} = riakc_pb_socket:start_link('127.0.0.1',10017).
{ok,<0.34.0>}
2> Object = riakc_obj:new(<<"test_age">>, <<"test1">>, <<"gopi & 1">>).
{riakc_obj,<<"test_age">>,<<"test1">>,undefined,[],
undefined,<<"gopi & 1">>}
3> riakc_pb_socket:put(Pid,Object).
ok
4> Mapf = fun(Obj,_,_) -> [{I,1}|| I <- binary_to_term(riak_object:get_value(Object))] end.
#Fun<erl_eval.18.82930912>
5> {ok, [{0,[R]}]} = riakc_pb_socket:mapred(Pid,<<"test_age">>,[{map,{qfun,Mapf},none,true}])
5> .
** exception error: no match of right hand side value {error,<<"{\"phase\":0,\"error\":\"function_clause\",\"input\":\"{ok,{r_object,<<\\\"test_age\\\">>,<<\\\"test1\\\">>,[{r_content,{dict"...>>}
我做错了,我无法理解。请
答案 0 :(得分:0)
问题在于您的地图功能:
Mapf = fun(Obj,_,_) -> [{I,1}|| I <- binary_to_term(riak_object:get_value(Object))] end.
执行此操作时,Obj
将包含r_object记录,但Object
将不确定。您可能打算使用:
Mapf = fun(Obj,_,_) -> [{I,1}|| I <- binary_to_term(riak_object:get_value(Obj))] end.
您存储的值是二进制<<"gopi & 1">>
,它是binary_to_term
调用返回的值。然后列表推导有效[{I,1}|| I <- <<"gopi & 1">>]
会导致bad_generator错误。为了使用这个map函数,所有的值都需要是Erlang列表。