Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.51/47: Рейтинг темы: голосов - 47, средняя оценка - 4.51
0 / 0 / 0
Регистрация: 22.05.2010
Сообщений: 116

Вывод уникальных данных из MySQL

15.05.2011, 19:46. Показов 8694. Ответов 16
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как сделать вывод из MySql таблицы уникальных данных.
Например таблица содержит.

строка 1 столбец 1;строка 1 столбец 2;строка 1 столбец 3; данные1
строка 2 столбец 1;строка 2 столбец 2;строка 2 столбец 3; данные2
строка 3 столбец 1;строка 3 столбец 2;строка 3 столбец 3; данные1
строка 4 столбец 1;строка 4 столбец 2;строка 4 столбец 3; данные1
строка 5 столбец 1;строка 5 столбец 2;строка 5 столбец 3; данные8
строка 6 столбец 1;строка 6 столбец 2;строка 6 столбец 3; данные1
строка 7 столбец 1;строка 7 столбец 2;строка 7 столбец 3; данные2

Как вывести их этой таблицы данные из последнего столбца.
Так чтоб выводились только уникальные значения. А именно:
данные1,данные2,данные8
Желательно. если нетрудно. занесите данные в php массив.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.05.2011, 19:46
Ответы с готовыми решениями:

Вывод уникальных данных MySQL без пустых значений
Люди добрые подскажите как вывести уникальные значения исключив из результата пустые значения? Меня интересует сам запрос Структура...

Сравнение данных и вывод уникальных
В бд находятся даты и числа в одной строке (формат id,sum,date) пытаюсь сделать график сумм за даты, т.е пытаюсь вывести каждый день и...

Вывод уникальных данных с двух таблиц
Всем добрый день. Есть две таблицы с одинаковыми полями - Date (datetime), LagerID (int) и FilID(int) Необходимо вывести с этих таблиц...

16
4 / 4 / 3
Регистрация: 25.05.2009
Сообщений: 2,576
15.05.2011, 20:49
а разве group by не то, что нужно?
другое дело? если ты неправильно используешь group by

GROUP BY
0
0 / 0 / 0
Регистрация: 22.05.2010
Сообщений: 116
15.05.2011, 21:47  [ТС]
Я же не профессиональный програмист. Я уже сделал это на PHP но на это скрипту нужно много процессорного времени и памяти чтобы обработать и вывести уникальные данные.
Я прошу вас привести конкретный пример для моей сетуации.
Пожалуйста не надо делать ссылок на мануал.
0
1 / 1 / 5
Регистрация: 25.04.2010
Сообщений: 121
16.05.2011, 01:26
PHP
1
2
3
4
5
6
7
8
<?
  // выборка данных из последнего столбца 'data' из нужной таблицы 'table1'
$query = 'select distinct data from table1'
  // заметь ключевое слово 'distinct' :))
$result = mysql_query($query);
$res    = mysql_fetch_array($result);
  // res - массив данных :)
?>
0
0 / 0 / 0
Регистрация: 22.05.2010
Сообщений: 116
16.05.2011, 07:42  [ТС]
Для SJack.
Ваш вариант не работает. так как выводит только первый результат из нужной колонки.
MySQL 4.1.8
0
4 / 4 / 3
Регистрация: 25.05.2009
Сообщений: 2,576
16.05.2011, 10:46
я бы с удовольствие привёл бы тебе пример конкретно на втоём примере
но из того как ты представил данные
строка 1 столбец 1;строка 1 столбец 2;строка 1 столбец 3; данные1
строка 2 столбец 1;строка 2 столбец 2;строка 2 столбец 3; данные2
строка 3 столбец 1;строка 3 столбец 2;строка 3 столбец 3; данные1
строка 4 столбец 1;строка 4 столбец 2;строка 4 столбец 3; данные1
строка 5 столбец 1;строка 5 столбец 2;строка 5 столбец 3; данные8
строка 6 столбец 1;строка 6 столбец 2;строка 6 столбец 3; данные1
строка 7 столбец 1;строка 7 столбец 2;строка 7 столбец 3; данные2

я нихрена не понял.

То, что я посоветовал, используется так
SQL
1
SELECT * FROM TABLE GROUP BY COLUMN
таким образом, если у тебя в столбце по которму мы группируем есть одинаковые значения, это значение ты получишь только один раз.
Создай пробную таблицу и попрактикуйся!
Тебя я кстати помню не первый год здесь, так что твоё заявления по поводу мануала меня порядком удивило.
Без чтения мануала не обойтись!
0
1 / 1 / 5
Регистрация: 25.04.2010
Сообщений: 121
16.05.2011, 11:10
Извини, counters, я действительно немного ошибся, поправлюсь:
PHP
1
2
3
4
5
6
<?
// выборка данных из последнего столбца 'data' из нужной таблицы 'table1'
$query = 'select distinct data from table1';
// заметь ключевое слово 'distinct' :))
$result = mysql_query($query);
?>
После этого можно сформировать массив выходных данных так:
PHP
1
2
3
4
5
6
7
8
<?
$i = 0;
while ($res = mysql_fetch_object($result)){
 $massiv[$i] = $res->data;
 $i++;
}
// $massiv - массив данных :)
?>
Вроде так, проверь. Однако можно всегда сделать разными способами. Например после формирования $result, обращаться к массиву выходных данных, например i-ая строка и j-ый столбец: mysql_result($result, $i, $j). Удачи!
0
4 / 4 / 3
Регистрация: 25.05.2009
Сообщений: 2,576
16.05.2011, 11:53
SJack - а ты уверен, что group by не то, что нужно?
0
1 / 1 / 5
Регистрация: 25.04.2010
Сообщений: 121
16.05.2011, 13:56
не уверен, но может быть, надо попробовать в командной строке мускула, но так впадло ) Но думаю можно разными способами решить поставленную задачу
0
0 / 0 / 0
Регистрация: 22.05.2010
Сообщений: 116
16.05.2011, 19:08  [ТС]
SJack ваш пример думаю работает но содержит много обращений в MySql базе. Данную вещь я уже давно реализовал. База данных достаточно большая и на выполнение этой операции потребудется много времени и памяти.

sl_play то что вы посоветовали
select * from table group by column
действительно функционирует как раз так как мне нужно. По крайней мере так было при прямом обращении в MySql серверу.
Пожалуйста помогите вывести это на экран скриптом PHP c минимальным временем выполнения
Мануал, к сажелению, читать я просто неуспеваю так как много другой работы. Но то что я когда нибудь делал я могу повторить без проблем. Раньше мне этого хватало но сейчас потребности значительно растут. И простейшие функции с которыми я привык общатся не справляются со свой задачей, вот и приходится искать новые пути с целью повышения быстрордействия вебприложений.
0
1 / 1 / 5
Регистрация: 25.04.2010
Сообщений: 121
16.05.2011, 20:34
Вывод на страницу:
PHP
1
2
3
4
5
6
7
8
<?
// $query - любой запрос с 'group by' или 'distinct'
$result = mysql_query($query); // единственное обращение к СУБД
while ($res = mysql_fetch_array($result)){
 echo '$res[0] $res[1] ... ';  
// вывод на экран по одной записи
}
?>
0
4 / 4 / 3
Регистрация: 25.05.2009
Сообщений: 2,576
16.05.2011, 22:37
мне с самого начала было понятно, что group by - это то, что нужно.
выше SJack привёл пример запроса и вывода контента в броузер, им вполне можно пользоваться!
0
0 / 0 / 0
Регистрация: 22.05.2010
Сообщений: 116
18.05.2011, 01:19  [ТС]
Вот как оказывается всё просто.
И чему только не научишся иногда не проходя мимо вашего форума.
Спасибо вам большое sl_play и SJack !!!
0
0 / 0 / 0
Регистрация: 22.05.2010
Сообщений: 116
18.05.2011, 01:27  [ТС]
SJack а вот в вашем отрезке скрипта
PHP
1
2
3
4
5
6
7
<?
// $query - любой запрос с 'group by' или 'distinct'
$result = mysql_query($query); // единственное обращение к СУБД
while ($res = mysql_fetch_array($result)){
echo '$res[0] $res[1] ... '; // вывод на экран по одной записи
}
?>
действительно единственное обращение в Базе данных ?
Или как мне кажется их ровно столько, сколько уникальных значений в таблице ?
Разьясните пожалуйста, в целях повышения образованности!!!
0
4 / 4 / 3
Регистрация: 25.05.2009
Сообщений: 2,576
18.05.2011, 10:20
mysql_query($query); - вот единственное обращение, всё остальное работает уже с ответом полученым из мускл, тоесть с массивом
0
1 / 1 / 5
Регистрация: 25.04.2010
Сообщений: 121
18.05.2011, 10:29
Функция $result = mysql_query($query) посылает запрос $query базе данных, к которой зараннее подконнектились. Это единственное обращение в данном скрипте к СУБД. Дальше мы работаем с $result типа int. А результат запроса хранится в памяти сервера. И коду ПХП, чтобы получить результат запроса нужно лишь указать в нужной функции (например mysql_fetch_array) лишь идентификатор $result. Дальше никаких обращений к базе данных - лишь к памяти сервера.
0
0 / 0 / 0
Регистрация: 22.05.2010
Сообщений: 116
18.05.2011, 23:57  [ТС]
Спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.05.2011, 23:57
Помогаю со студенческими работами здесь

Запрос sql: совместный вывод уникальных и не уникальных столбцов
Добрый день, уважаемые программисты! Вопрос следующий: каким образом вывести уникальные значения столбоцов совместно с неуникальными? ...

Ajax отправка данных из формы в базу mysql и вывод из базы mysql
$(function() { $('#chat_submit').click(function(e) { e.preventDefault(); var chat_name =...

Вывод данных из базы данных MySQL в PHP в виде дерева.
У нас в сети решили сделать портал-базу по рефератам. Все я сделал остались две траблы, про первую я здесь и пишу. Итак, имеется база с...

Вывод данных из mysql. Максимум 10 данных на страницу!
Имеется ниже код, который выводить данные из mysql в таблицу (пользователю) в личный кабинет! Сейчас этих данных в mysql очень много,...

Вывод необходимых данных из базы данных MySQL
Всем привет. Подскажите как проще всего реализовать вывод необходимых данных из бд, проблема в следующем: На сайтах висят формы заказа...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru