Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
 
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> Как удалять из много мерного массива элементы по у
bkmz1984  
 ۩  [x] Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Новичок
*

Профиль
Группа: Пользователь
Сообщений: 1
Пользователь №: 43171
На форуме: 4 месяца, 23 дня
Карма:




Есть таблица в mysql.
Она имеет если упрощенно такой вид:
-------------------
| callid | status |
-------------------
| 1 | an |
-------------------
| 1 | an |
-------------------
| 1 | no an |
-------------------
| 2 | an |
-------------------
| 2 | no an |
-------------------
| 3 | no an |
-------------------

Я получаю из него 1000 записей. Как исключить из результата все записи со имеющее в status "no an" если была хоть одна запись с таким же callid но со status "an"

Я решил приблизительно так: Но чувствую решил я или неправильно или не оптимально или и то и другое

<?php

// Данные для отладки
$data[0] = array("agent"=>"a1", "disposition"=>"ANSWERED", "callid"=>"12");
$data[1] = array("agent"=>"a2", "disposition"=>"NO ANSWER", "callid"=>"12");
$data[2] = array("agent"=>"a3", "disposition"=>"NO ANSWER", "callid"=>"12");
$data[3] = array("agent"=>"a4", "disposition"=>"NO ANSWER", "callid"=>"13");
$data[4] = array("agent"=>"a5", "disposition"=>"ANSWERED", "callid"=>"13");
$data[5] = array("agent"=>"a6", "disposition"=>"BUSY", "callid"=>"13");
$data[6] = array("agent"=>"a7", "disposition"=>"NO ANSWER", "callid"=>"14");



// Отладка
print ("<pre>");
print_r($data);
print ("</pre>");

$for_del = array();

for ($i = 0; $i < count($data); $i++) {
if ($data[$i]['disposition'] == "ANSWERED") {
for ($j = 0; $j < count($data); $j++) {
if ($data[$j]['callid'] == $data[$i]['callid'] AND $data[$j]['disposition'] == "NO ANSWER") {
$for_del[] = $j;
}
}
}
}


foreach ($for_del as $key => $value){
unset($data[$value]);
}

// Отладка
print ("<pre>");
print_r($data);
print ("</pre>");

echo json_encode($data);

?>


Это сообщение отредактировал bkmz1984 - 15.07.2016 - 10:11
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Kusss  
Дата
Цитировать сообщение

Пользователь сейчас на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1355
Пользователь №: 28976
На форуме: 5 лет, 4 месяца, 9 дней
Карма: 77




по моему это решается на уровне запроса.
но не совсем понятна суть вопроса. Что нужно исключить и по какому принципу.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
kaww  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1755
Пользователь №: 20757
На форуме: 6 лет, 10 месяцев, 5 дней
Карма: 184




Как уже сказал Kusss, решается на стороне БД. http://www.sqlfiddle.com/#!9/91d89/2
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темы Ответ в темуСоздание новой темыСоздание опроса