Puncte:0

Cum pot incrementa și salva o valoare întreagă într-o singură operațiune pentru a evita condițiile de cursă?

drapel km

Cum pot incrementa și salva o valoare întreagă într-o singură operațiune pentru a evita condițiile de cursă?

Cu MySQL, aș putea folosi următoarea interogare.

INSERT în mytable (autentificare)
 SELECT max(autentificare) + 1
 DIN mytable

Momentan folosesc următorul cod.

$interogare = \Drupal::entityQuery('nod')->condition('tip', 'bond')
  ->condition('field_para_identifier.entity:paragraph.field_bond_pending_id', 'NULL', 'IS NOT NULL')
  ->sort('field_para_identifier.entity:paragraph.field_bond_pending_id', 'DESC')
  ->interval(0, 1);
$rezultate = $interogare->execute();
$biggest_pending_id_entity_id = array_pop($rezultate);
$next_pending_id = 1;

dacă ($biggest_pending_id) {
  $next_pending_id = intval($biggest_pending_id) + 1;
}

$identificator = $bond->get('field_para_identifier')->getValue();
$identifierParagraph = Paragraph::load($identifier[0]['target_id']);
$identifierParagraph->set('field_bond_pending_id', $next_pending_id);
$identificatorParagraf->salvare();
Jaypan avatar
drapel de
Puteți utiliza o tranzacție cu o derulare: https://www.drupal.org/docs/drupal-apis/database-api/database-transactions

Postează un răspuns

Majoritatea oamenilor nu înțeleg că a pune multe întrebări deblochează învățarea și îmbunătățește legătura interpersonală. În studiile lui Alison, de exemplu, deși oamenii își puteau aminti cu exactitate câte întrebări au fost puse în conversațiile lor, ei nu au intuit legătura dintre întrebări și apreciere. În patru studii, în care participanții au fost implicați în conversații ei înșiși sau au citit transcrieri ale conversațiilor altora, oamenii au avut tendința să nu realizeze că întrebarea ar influența – sau ar fi influențat – nivelul de prietenie dintre conversatori.