Điểm:0

Làm cách nào tôi có thể tăng và lưu một giá trị số nguyên trong một thao tác để tránh các điều kiện tương tranh?

lá cờ km

Làm cách nào tôi có thể tăng và lưu một giá trị số nguyên trong một thao tác để tránh các điều kiện tương tranh?

Với MySQL, tôi có thể sử dụng truy vấn sau.

CHÈN vào mytable (đăng nhập)
 CHỌN tối đa (lần đăng nhập) + 1
 TỪ mytable

Tôi hiện đang sử dụng đoạn mã sau.

$query = \Drupal::entityQuery('node')->condition('type', 'bond')
  ->điều kiện('field_para_identifier.entity:paragraph.field_bond_pending_id', 'NULL', 'IS NOT NULL')
  ->sắp xếp('field_para_identifier.entity:paragraph.field_bond_pending_id', 'DESC')
  ->phạm vi(0, 1);
$results = $query->execute();
$biggest_pending_id_entity_id = array_pop($results);
$next_pending_id = 1;

nếu ($biggest_pending_id) {
  $next_pending_id = intval($biggest_pending_id) + 1;
}

$identifier = $bond->get('field_para_identifier')->getValue();
$identifierParagraph = Đoạn::load($identifier[0]['target_id']);
$identifierParagraph->set('field_bond_pending_id', $next_pending_id);
$identifierParagraph->save();
Jaypan avatar
lá cờ de
Bạn có thể sử dụng giao dịch có quay lui: https://www.drupal.org/docs/drupal-apis/database-api/database-transactions

Đăng câu trả lời

Hầu hết mọi người không hiểu rằng việc đặt nhiều câu hỏi sẽ mở ra cơ hội học hỏi và cải thiện mối quan hệ giữa các cá nhân. Ví dụ, trong các nghiên cứu của Alison, mặc dù mọi người có thể nhớ chính xác có bao nhiêu câu hỏi đã được đặt ra trong các cuộc trò chuyện của họ, nhưng họ không trực giác nhận ra mối liên hệ giữa câu hỏi và sự yêu thích. Qua bốn nghiên cứu, trong đó những người tham gia tự tham gia vào các cuộc trò chuyện hoặc đọc bản ghi lại các cuộc trò chuyện của người khác, mọi người có xu hướng không nhận ra rằng việc đặt câu hỏi sẽ ảnh hưởng—hoặc đã ảnh hưởng—mức độ thân thiện giữa những người đối thoại.