Saltar para o conteúdo principal
Versão: v20 R4 BETA

$atomic/$atOnce

Permite que as ações no pedido REST estejam numa transação. Se não houver erros, a transação é validada. Caso contrário, a transação é cancelada.

Descrição

Quando tiver várias ações em conjunto, pode utilizar $atomic/$atOnce para se certificar de que nenhuma das ações será terminada se uma delas falhar. Pode utilizar $atomic ou $atOnce.

Exemplo

Chamamos o seguinte pedido REST numa transação.

POST /rest/Employee?$method=update&$atomic=true

Dados POST:

[
{
"__KEY": "200",
"firstname": "John"
},
{
"__KEY": "201",
"firstname": "Harry"
}
]

Obtemos o seguinte erro na segunda entidade e, por conseguinte, a primeira entidade também não é guardada:

{
"__STATUS": {
"success": true
},
"__KEY": "200",
"__STAMP": 1,
"uri": "/rest/Employee(200)",
"__TIMESTAMP": "!!2020-04-03!!",
"ID": 200,
"firstname": "John",
"lastname": "Keeling",
"isWoman": false,
"numberOfKids": 2,
"addressID": 200,
"gender": false,
"address": {
"__deferred": {
"uri": "/rest/Address(200)",
"__KEY": "200"
}
},
"__ERROR": [
{
"message": "Cannot find entity with \"201\" key in the \"Employee\" dataclass",
"componentSignature": "dbmg",
"errCode": 1542
}
]
}

Embora o salário da primeira entidade tenha um valor de 45000, este valor não foi guardado no servidor e o timestamp (__STAMP) também não foi modificado. Se recarregarmos a entidade, veremos o valor anterior.