веб-сервисы Amazon — AWS SDK для PHP DynamoDB PutItem только для ненулевых переменных

Я вставляю переменные в AWS DynamoDB из массива
$ dbf [$ a] [‘variable1’], $ dbf [$ a] [‘variable2’], $ dbf [$ a] [‘variable3’] …

для некоторого $ a установлены только ‘variable1’ и ‘variable2’, и
для других $ a все переменные # установлены.

Приведенный ниже код не будет работать, потому что нулевые или не установленные переменные не
позволил.

Есть ли способ в цикле, чтобы попытаться «PutItem» только для переменных, которые установлены?

foreach($dbf as $day)
{
$result = $client->PutItem(array(
'TableName' => 'AWIS',
'Item' => array(
'id' => array('S' =>  $day['id']),
'date'=> array('S' => $day['date']),
'max'=> array('N' => $day['max']),
'min'=> array('N' => $day['min']),
'pre'=> array('N' => $day['pre']),
'max_soil_temp'=> array('N' => $day['max_soil_temp']),
'min_soil_temp'=> array('N' => $day['min_soil_temp']),
'evap'=> array('N' => $day['evap']),
'veg_wetting'=> array('N' => $day['veg_wetting']),
'solar_rad'=> array('N' => $day['solar_rad']),
'ob_temp'=> array('N' => $day['ob_temp']),
'adj_min'=> array('N' => $day['adj_min']),
'chill_hours'=> array('N' => $day['chill_hours'])
),
));
}

3

Решение

Вы можете сделать, как:

if ($yourValue) {
$params['yourKey'] = array(
'Action' => 'PUT',
'Value' => array(
Type::STRING => $yourValue
)
);
}

$response = $Client->updateItem(array(
"TableName" => "tableName",
"Key" => array(
"Id" => array(
Type::STRING => $Id
)
),
"AttributeUpdates" => $params
)
);

Установите все параметры, доступные в цикле, и обновите только те значения, которые доступны

надеюсь, это поможет

1

Другие решения

Других решений пока нет …