Лучший способ обновить / добавить факт в БД?
Скажем, у меня есть такие факты:
fact(abc,2).
Я хочу что-то вроде этого (псевдокод):
fact_update(Functor,Name,AddToValue) :-
if Fact_exist then update_fact : NewVal is CurrentValue + AddToValue
else create_new_fact : Functor(Name,AddToValue)
Я пробовал 2 разных способа. Первое мне не очень нравится:
fact_add(Functor,Name,Val) :-
Fact =.. [Functor, Name, Val],
assert(Fact),
say([fact, Fact]).
fact_update(true, Functor,Name,Val) :-
Fact =.. [Functor, Name, Amt],
Fact,
retractall(Fact),
X is Amt + Val,
fact_add(Functor,Name,X). %% retractall??
fact_update(false,Functor,Name,Val) :-
fact_add(Functor,Name,Val).
Второе не работает:
fact_update(Functor,Name,Val) :-
Fact =.. [Functor, Name, Amt],
(
Fact -> retractall(Fact)
;
(
(nonvar(Amt) -> NewAmt is Amt + Val ; NewAmt is Val),
Fact =.. [Functor, Name, NewAmt],
assert(Fact)
)
),
say([upd_fact, Fact]).
Потому что когда Fact
не удается Amt
не создается, поэтому я всегда получаю NewAmt is Val
,
1 ответ
Решение
Я бы написал
fact_update(Functor,Name,AddToValue) :-
Curr =.. [Functor,Name,CurrVal],
( retract(Curr)
-> NextVal is CurrVal+AddToValue,
Next =.. [Functor,Name,NextVal]
; Next =.. [Functor,Name,AddToValue]
),
assertz(Next).