С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/229: Рейтинг темы: голосов - 229, средняя оценка - 4.53
 Аватар для Vinemax
149 / 117 / 10
Регистрация: 12.09.2011
Сообщений: 785

Отсеивание повторяющихся значений

09.10.2012, 23:15. Показов 42260. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет всем!

Пишу программу на VB.NET. Подскажите, пожалуйста, есть ли какая-то команда SQL-запроса, которая бы отсеивала повторяющиеся значения? Делаю так:

VB.NET
1
cmd = "SELECT [" & Column & "] FROM [" & Table & "] WHERE [" & Column & "] LIKE '" & Text & "%'"
После выполнения этого запроса, в Reader'е появляются значения из нужной мне колонки таблицы в соответствии с условием. Но в этой таблице много одинаковых значений, нужно чтобы все значения были в единственном экземпляре. Возможно ли это сделать SQL-запросом?

Спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.10.2012, 23:15
Ответы с готовыми решениями:

Нумерация повторяющихся значений в строке
Всем привет. В sql совсем новичок. Кто-нибудь сможет обьяснить, как пронумеровать повторяющиеся значения в столбце Name определенным...

Запрет вывода повторяющихся значений
В упрощенном виде есть такая вещь: 2 таблицы Предметы и Семестры: Предметы Id предмета Название предмета Семестры Id...

Сумма значений повторяющихся имен в БД
Доброго времени суток! Есть таблица: |_Имя_|_Значение1_|_Значение2_|_Значение3_| |------+------------+------------+-------------| |...

7
187 / 180 / 29
Регистрация: 26.05.2011
Сообщений: 856
10.10.2012, 07:30
Попробуйте поставить слово DISTINCT после SELECT
1
 Аватар для Vinemax
149 / 117 / 10
Регистрация: 12.09.2011
Сообщений: 785
12.10.2012, 21:03  [ТС]
sks1904, пробовал, но у меня в некоторых случаях к строке запроса добавляется параметр ORDER BY и в этом случае выкидывает ошибку о конфликте DISTINCT и ORDER BY
0
 Аватар для reiteriX
685 / 241 / 13
Регистрация: 02.04.2009
Сообщений: 692
13.10.2012, 11:01
Vinemax, выложите сюда запрос, который выдает вам эту ошибку
2
 Аватар для Cabery
3 / 3 / 0
Регистрация: 02.10.2012
Сообщений: 40
13.10.2012, 19:51
select * from ( запрос с DISTINCT )a order by тогда он сначала уникальные данные соберёт и их потом упорядочит
1
 Аватар для Vinemax
149 / 117 / 10
Регистрация: 12.09.2011
Сообщений: 785
14.10.2012, 01:06  [ТС]
reiteriX, вот мой код на VB.NET, уверен, поймете суть:

VB.NET
1
2
3
4
5
6
7
8
9
10
cmdText = "SELECT [" & dicColumn & "] FROM [" & dicTable & "] WHERE [" & dicColumn & "] LIKE '" & txt & "%'"
 
   If (AdditionalFilter IsNot Nothing) And (AdditionalFilterColumn IsNot Nothing) Then
       cmdText &= " AND [" & AdditionalFilterColumn & "] LIKE '" & AdditionalFilter.TextBox1.Text & "'"
   End If
 
   If PriorFiled IsNot Nothing Then cmdText &= " ORDER BY [" & PriorFiled & "] DESC"
 
 
   command = New OleDbCommand(cmdText, dicConnection) : reader = command.ExecuteReader()

...т.е. ошибка фактически выпадает на таком запросе:

SQL
1
SELECT DISTINCT [" & dicColumn & "] FROM [" & dicTable & "] WHERE [" & dicColumn & "] LIKE '" & txt & "%' ORDER BY [" & PriorFiled & "] DESC
0
 Аватар для reiteriX
685 / 241 / 13
Регистрация: 02.04.2009
Сообщений: 692
14.10.2012, 11:31
Vinemax, если в order by в select'e у Вас допустим поле: NAME, а в order by у Вас ID, то при distinct действительно будет ошибка, т.к. без distinct сотрировка по полю не указанному в select возможна, а если пишите distinct то должны в select дописать еще и поле по которому сотрировку делаете.

пример для наглядности:
T-SQL
1
2
3
4
5
6
7
select distinct  
    ID_DOC
from
    Kassa
where 
    ID_DOC like '1288%'
order by ID_DOC asc
Работает как надо)

T-SQL
1
2
3
4
5
6
7
select distinct  
    ID_DOC
from
    Kassa
where 
    ID_DOC like '1288%'
order by ID asc
не работает.

Следовательно,
1) либо в select дописываете поле по которому сортировку делаете
2) либо сортируете по полю из select
3) либо делаете свой запрос вложенным и по полученным значениям делаете distinct как сказал Вам Cabery.
1
 Аватар для Vinemax
149 / 117 / 10
Регистрация: 12.09.2011
Сообщений: 785
15.10.2012, 00:07  [ТС]
reiteriX, спасибо! Вроде идет ))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.10.2012, 00:07
Помогаю со студенческими работами здесь

Пример повторяющихся групп значений атрибутов
Не понимаю что значит повторяющиеся группы значений атрибутов таблицы. Нашел в интернете определение: Повторяющейся группой называется...

Отсеивание повторяющихся значений
Здравствуйте всем! Помогите пожалуйста с такой проблемой: имеется ADOQuery с таким вот запросом: SELECT DISTINCT LichData.ID,...

Отсеивание повторяющихся решений в Turbo Prolog
Добрый вечер. Проблема заключается в том, что Turbo Prolog выдаёт повторяющиеся результаты как разные. Можно как-то заставить его...

Отсеивание лишних значений
Здравствуйте. У меня есть 3 таблицы. 1 таблица - код авиакомпании и её название; 2 таблица - код рейса, код авиакомпании и направление...

Получение значений из dataGridView, отсеивание исключений
Здравствуйте. Получаю значения из ячейки в String st = dataGridView1.Rows.Cells.Value.ToString(); но если пользователь не ввел туда...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 07.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru