Тайм-аут сервера при операции запроса Dynamo DB для получения элементов из таблицыPhp

Кемеровские программисты php общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Тайм-аут сервера при операции запроса Dynamo DB для получения элементов из таблицы

Сообщение Anonymous »

У меня есть массив идентификаторов (eventids), которые могут содержать миллионы или миллиарды идентификаторов внутри таблицы. Я использую цикл for, чтобы просмотреть каждый идентификатор и получить элемент из таблицы базы данных Dynamo, используя операцию запроса в PHP. Однако, поскольку операция запроса обрабатывает большой объем информации в моей таблице, операция запроса выполняет свою работу слишком долго. Итак, в этом случае я не получаю никакого результата, потому что у меня есть тайм-аут. Следующий код пытается выполнить эту операцию, но для больших объемов информации это не удается. Мне интересно, есть ли у вас какие-либо рекомендации или предложения о том, как сделать операцию запроса более быстрой и выполнимой для большого количества идентификаторов внутри массива $sfweventarrayRDS?

for ($j = 0 ; $j < count($sfweventarrayRDS) ; $j++){
$keyconditions = array(
"eventid" => array(
"ComparisonOperator" => ComparisonOperator::EQ,
"AttributeValueList" => array(
array(Type::NUMBER => $sfweventarrayRDS[$j]["eventid"])
)
)
);

$sfweventarrayDynamo = Dynamo::getItems("eventlocation",$keyconditions,$limit);

if (count($sfweventarrayDynamo) > 0){

$timediffepoch = $sfweventarrayDynamo[0]["edatecreated"]["N"] - $sfweventarrayRDS[$j]["edatecreated"];
$timediffstandard = new DateTime("@$timediffepoch");

if ($timediffstandard->format('i') >= 5){
$starttimeepoch = $sfweventarrayRDS[$j]["edatecreated"];
$endtimeepoch = $sfweventarrayDynamo[0]["edatecreated"]["N"];
$starttimestandard = new DateTime("@$starttimeepoch");
$endtimestandard = new DateTime("@$endtimeepoch");

$each_event = array("eventid" => $sfweventarrayDynamo[0]["eventid"]["N"],
"organizationid" => $sfweventarrayRDS[$j]["organizationid"],
"userid" => $sfweventarrayDynamo[0]["userid"]["N"],
"starttime" => $starttimestandard->format('Y-m-d H:i:s'),
"endtime" => $endtimestandard->format('Y-m-d H:i:s'),
"location" => $sfweventarrayRDS[$j]["location"],
"startlatitude" => $sfweventarrayRDS[$j]["latitude"],
"startlongitude" => $sfweventarrayRDS[$j]["longitude"],
"endlatitude" => $sfweventarrayDynamo[0]["latitude"]["N"],
"endlongitude" => $sfweventarrayDynamo[0]["longitude"]["N"]);
array_push($safewalkeventsDynamo, $each_event);
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/261 ... om-a-table
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Php»